/* ==========================================================================
   FORM PATTERN LIBRARY · DARK · INLINED
   Self-contained — no site.css / manage.css. Safe to copy into any project.
   ========================================================================== */

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Lexend','Inter',system-ui,sans-serif;font-size:14px;line-height:1.5}
img{max-width:100%}
a{color:inherit}
button{font-family:inherit}

/* ============================== TOKENS ================================== */
:root{
  /* Brand */
  --c-primary:#22d3ee;          /* brighter cyan for dark contrast */
  --c-primary-d:#06b6d4;
  --c-primary-l:#67e8f9;
  --c-primary-bg:rgba(34,211,238,.12);
  --c-primary-bg-strong:rgba(34,211,238,.2);

  /* Status */
  --c-success:#10b981;
  --c-success-bg:rgba(16,185,129,.14);
  --c-warn:#fbbf24;
  --c-warn-bg:rgba(251,191,36,.14);
  --c-danger:#f43f5e;
  --c-danger-d:#e11d48;
  --c-danger-bg:rgba(244,63,94,.14);

  /* Neutral scale (slate inverted for dark) */
  --c-50:#f8fafc;
  --c-100:#f1f5f9;
  --c-200:#e2e8f0;
  --c-300:#cbd5e1;
  --c-400:#94a3b8;
  --c-500:#64748b;
  --c-600:#475569;
  --c-700:#334155;
  --c-800:#1e293b;
  --c-900:#0f172a;
  --c-950:#020617;

  /* Surface */
  --bg:#0b1220;
  --bg-soft:#0f172a;
  --surface:#1a2030;
  --surface-elevated:#222a3d;
  --surface-sunken:#0f172a;
  --line:#334155;
  --line-strong:#3f4a64;
  --line-soft:#1e293b;

  /* Text */
  --t-strong:#f8fafc;
  --t:#cbd5e1;
  --t-muted:#94a3b8;
  --t-subtle:#7e8b9e;

  /* Typography */
  --font:'Lexend','Inter',system-ui,sans-serif;
  --font-mono:'JetBrains Mono','Fira Code',monospace;

  /* Spacing (8pt) */
  --sp-1:4px; --sp-2:8px; --sp-3:12px; --sp-4:16px; --sp-5:20px;
  --sp-6:24px; --sp-7:32px; --sp-8:48px; --sp-9:64px;

  /* Radius */
  --r-sm:6px; --r-md:8px; --r-lg:12px; --r-xl:16px; --r-pill:999px;

  /* Shadow (subtle on dark — rely more on borders/elevation) */
  --shadow-xs:0 1px 2px rgba(0,0,0,.3);
  --shadow-sm:0 2px 4px rgba(0,0,0,.3);
  --shadow-md:0 4px 8px rgba(0,0,0,.4);
  --shadow-lg:0 12px 24px rgba(0,0,0,.5);
  --shadow-xl:0 24px 48px rgba(0,0,0,.6);
  --shadow-2xl:0 30px 60px rgba(0,0,0,.7);
  --shadow-focus:0 0 0 3px rgba(34,211,238,.35);

  /* Transitions */
  --t-fast:.12s cubic-bezier(.4,0,.2,1);
  --t-base:.18s cubic-bezier(.4,0,.2,1);

  /* Layout */
  --topbar-h:56px;
  --mg-group-nav-h:48px;
  --mg-imp-h:0px;
  --mg-fixed-stack-h:calc(var(--mg-imp-h) + var(--topbar-h) + var(--mg-group-nav-h));
  --toc-h:46px;
  --scroll-pad:calc(var(--topbar-h) + var(--toc-h) + 12px);
}

body{background:var(--bg);color:var(--t);padding-top:var(--mg-fixed-stack-h);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body:has(.mg-imp){--mg-imp-h:40px}

/* ============================== TOPBAR ================================== */
.mg-topbar{
  position:fixed;top:var(--mg-imp-h);left:0;right:0;z-index:1000;height:var(--topbar-h);
  background:var(--c-950);color:var(--t-strong);
  display:flex;align-items:center;border-bottom:1px solid var(--line-soft);
  box-shadow:var(--shadow-md);
}
.mg-topbar-inner{
  width:100%;max-width:1440px;margin:0 auto;
  display:flex;align-items:center;gap:14px;padding:0 24px;
}
.mg-brand{
  display:flex;flex-direction:column;font-weight:800;font-size:14px;color:var(--t-strong);
  white-space:nowrap;flex-shrink:0;padding-right:14px;
  border-right:1px solid var(--line);text-decoration:none;
}
.mg-brand small{
  font-size:9px;font-weight:700;color:var(--t-muted);
  text-transform:uppercase;letter-spacing:1.2px;margin-top:1px;
}
.mg-env{
  font-size:10px;font-weight:800;letter-spacing:1px;text-transform:uppercase;
  padding:3px 9px;border-radius:var(--r-pill);
  background:rgba(168,85,247,.18);color:#c084fc;border:1px solid rgba(168,85,247,.4);
}
.mg-search{flex:1;max-width:520px;position:relative}
.mg-search input{
  width:100%;height:34px;padding:0 12px 0 34px;
  background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:var(--r-md);
  color:var(--t-strong);font-size:13px;font-family:var(--font);
  transition:border-color var(--t-fast),background var(--t-fast);
}
.mg-search input::placeholder{color:var(--t-subtle)}
.mg-search input:focus{outline:none;background:rgba(255,255,255,.08);border-color:var(--c-primary)}
.mg-search .icn{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--t-muted);font-size:13px;pointer-events:none}
.mg-search kbd{
  position:absolute;right:8px;top:50%;transform:translateY(-50%);
  font-size:10px;font-weight:700;color:var(--t-muted);
  background:rgba(255,255,255,.05);padding:2px 6px;border-radius:4px;
  border:1px solid var(--line);font-family:var(--font-mono);
}
.mg-actions{display:flex;align-items:center;gap:4px;margin-left:auto;flex-shrink:0}
.mg-icon-btn{
  width:36px;height:36px;border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;
  color:var(--t-muted);background:transparent;border:none;cursor:pointer;
  font-size:15px;transition:var(--t-fast);position:relative;
}
.mg-icon-btn:hover{background:rgba(255,255,255,.08);color:var(--t-strong)}
.mg-icon-btn .badge-dot{
  position:absolute;top:7px;right:7px;width:7px;height:7px;
  background:var(--c-warn);border:2px solid var(--c-950);border-radius:50%;
}
.mg-theme-toggle{
  display:inline-flex;align-items:center;gap:1px;
  background:rgba(255,255,255,.05);border:1px solid var(--line);
  border-radius:var(--r-md);padding:2px;height:32px;
}
.mg-theme-toggle a{
  display:inline-flex;align-items:center;justify-content:center;
  width:30px;height:26px;border-radius:var(--r-sm);
  font-size:13px;color:rgba(255,255,255,.55);
  text-decoration:none;transition:var(--t-fast);cursor:pointer;
}
.mg-theme-toggle a:hover{color:#fff;background:rgba(255,255,255,.08)}
.mg-theme-toggle a[aria-selected=true]{
  background:var(--c-primary);color:var(--c-950);
}
.mg-pill{
  display:flex;align-items:center;gap:7px;padding:3px 4px 3px 11px;
  background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:var(--r-pill);
  color:var(--t-strong);font-size:12.5px;font-weight:600;cursor:pointer;
  transition:var(--t-fast);font-family:var(--font);
}
.mg-pill:hover{background:rgba(255,255,255,.08)}
.mg-pill .av{
  width:26px;height:26px;border-radius:50%;
  background:linear-gradient(135deg,var(--c-primary),var(--c-primary-l));
  color:var(--c-950);display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:11px;
}
.mg-pill .arr{font-size:9px;opacity:.6;margin:0 6px 0 -2px}

/* =========================== MANAGE GROUP NAV =========================== */
.mg-group-nav{
  position:fixed;top:calc(var(--mg-imp-h) + var(--topbar-h));left:0;right:0;z-index:940;
  background:var(--bg-soft);border-bottom:1px solid var(--line-soft);
  box-shadow:0 10px 24px rgba(0,0,0,.12);
}
.mg-group-nav__inner{
  width:100%;max-width:1440px;margin:0 auto;
  min-height:48px;padding:6px 24px;
  display:flex;align-items:center;flex-wrap:wrap;gap:4px;
}
.mg-group-nav__group{position:relative;flex:0 0 auto}
.mg-group-nav__group::after{
  content:"";position:absolute;top:100%;left:0;display:none;
  width:min(310px,calc(100vw - 32px));height:12px;z-index:1;
}
.mg-group-nav__trigger{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  min-height:36px;padding:0 13px;border:1px solid transparent;
  border-radius:var(--r-md);color:var(--t);font-size:13px;font-weight:800;
  line-height:1;text-decoration:none;white-space:nowrap;
  transition:background var(--t-fast),border-color var(--t-fast),color var(--t-fast);
}
.mg-group-nav__trigger .arr{color:var(--t-subtle);font-size:10px;transform:translateY(-1px)}
.mg-group-nav__group:hover .mg-group-nav__trigger,
.mg-group-nav__group:focus-within .mg-group-nav__trigger{
  background:var(--surface);border-color:var(--line);color:var(--t-strong);
}
.mg-group-nav__group:hover::after,
.mg-group-nav__group:focus-within::after{display:block}
.mg-group-nav__group.is-active .mg-group-nav__trigger{
  background:var(--c-primary-bg-strong);border-color:var(--c-primary);color:var(--c-primary-l);
}
.mg-group-nav__panel{
  position:absolute;top:calc(100% + 8px);left:0;z-index:2;display:none;
  width:min(310px,calc(100vw - 32px));padding:8px;background:var(--surface);
  border:1px solid var(--line-strong);border-radius:var(--r-lg);box-shadow:var(--shadow-xl);
}
.mg-group-nav__group:hover .mg-group-nav__panel,
.mg-group-nav__group:focus-within .mg-group-nav__panel{display:grid;gap:3px}
.mg-group-nav__link{
  display:flex;align-items:center;gap:10px;min-height:38px;padding:8px 10px;
  border-radius:var(--r-md);color:var(--t);font-size:13px;font-weight:700;
  line-height:1.25;text-decoration:none;
}
.mg-group-nav__link:hover,
.mg-group-nav__link:focus-visible{background:var(--surface-elevated);color:var(--t-strong);outline:none}
.mg-group-nav__link.is-active{background:var(--c-primary-bg);color:var(--c-primary-l)}
.mg-group-nav__ic{
  display:inline-flex;align-items:center;justify-content:center;flex:0 0 26px;
  width:26px;height:26px;border-radius:var(--r-sm);background:var(--surface-elevated);
  font-size:13px;
}
@media (max-width:900px){
  .mg-group-nav__inner{flex-wrap:nowrap;padding:0 16px;overflow-x:auto}
  .mg-group-nav__panel{
    position:fixed;top:calc(var(--topbar-h) + 50px);left:16px;right:16px;width:auto;
  }
}

/* ====================== IMPERSONATION BANNER ============================ */
.mg-imp{
  position:fixed;top:0;left:0;right:0;z-index:1100;min-height:var(--mg-imp-h);
  box-sizing:border-box;
  display:flex;align-items:center;gap:14px;
  background:linear-gradient(180deg,rgba(251,191,36,.15) 0%,rgba(251,191,36,.08) 100%);
  border-bottom:1px solid rgba(251,191,36,.3);
  color:#fcd34d;padding:8px 24px;
  font-size:12.5px;font-weight:600;
}
.mg-imp__icon{font-size:14px}
.mg-imp__text{flex:1}
.mg-imp__text strong{color:#fde68a;font-weight:700}
.mg-imp__back{
  background:rgba(251,191,36,.2);color:#fde68a;
  padding:5px 12px;border-radius:var(--r-sm);
  font-weight:700;font-size:12px;text-decoration:none;border:1px solid rgba(251,191,36,.3);
}
.mg-imp__back:hover{background:rgba(251,191,36,.3)}

/* ============================== COVER =================================== */
.pp-cover{
  background:radial-gradient(ellipse at 80% -20%, rgba(34,211,238,.25) 0%, transparent 60%),
             linear-gradient(180deg, var(--c-900) 0%, var(--c-950) 100%);
  color:#fff;padding:var(--sp-7) var(--sp-6) var(--sp-6);
  border-bottom:1px solid var(--line-soft);
}
.pp-cover-inner{max-width:1320px;margin:0 auto}
.pp-cover .ver{
  display:inline-flex;align-items:center;gap:7px;
  padding:4px 12px;border-radius:var(--r-pill);
  background:rgba(34,211,238,.12);border:1px solid rgba(34,211,238,.3);
  font-size:11px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;
  color:var(--c-primary-l);margin-bottom:var(--sp-3);
}
.pp-cover .ver .dot{width:6px;height:6px;border-radius:50%;background:var(--c-primary);box-shadow:0 0 8px var(--c-primary)}
.pp-cover h1{
  /* Issue 1 fix — explicit white text. */
  color:#fff;
  font-size:32px;font-weight:800;letter-spacing:-.4px;
  margin:0 0 var(--sp-2);line-height:1.1;
}
.pp-cover p.lede{
  font-size:15px;color:rgba(248,250,252,.75);max-width:760px;line-height:1.5;margin:0;
}
.pp-cover .meta{
  display:flex;flex-wrap:wrap;gap:var(--sp-5);margin-top:var(--sp-4);
  font-size:12.5px;color:rgba(248,250,252,.55);
}
.pp-cover .meta strong{color:var(--t-strong);font-weight:700}
.pp-cover .theme-toggle{
  display:inline-flex;gap:4px;margin-top:var(--sp-4);
  background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:var(--r-md);
  padding:3px;
}
.pp-cover .theme-toggle a{
  padding:6px 14px;font-size:12px;font-weight:700;text-decoration:none;
  border-radius:var(--r-sm);color:var(--t-muted);transition:var(--t-fast);
}
.pp-cover .theme-toggle a.active{background:var(--c-primary);color:var(--c-950)}
.pp-cover .theme-toggle a:not(.active):hover{color:var(--t-strong)}

/* ============================== TOC ===================================== */
.pp-toc{
  position:sticky;top:var(--topbar-h);z-index:30;
  background:rgba(11,18,32,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);height:var(--toc-h);
  padding:0 var(--sp-6);
}
.pp-toc-inner{
  max-width:1320px;margin:0 auto;display:flex;flex-wrap:nowrap;gap:6px;
  align-items:center;height:100%;overflow-x:auto;
  scrollbar-width:none;-ms-overflow-style:none;
}
.pp-toc-inner::-webkit-scrollbar{display:none}
.pp-toc-label{
  font-weight:800;letter-spacing:.4px;text-transform:uppercase;
  color:var(--t-muted);font-size:10px;margin-right:8px;flex-shrink:0;
}
.pp-toc a{
  /* Issue 5 fix — comfortable target size. */
  display:inline-flex;align-items:center;height:32px;padding:0 12px;
  border-radius:var(--r-sm);background:var(--surface);border:1px solid var(--line);
  color:var(--t);text-decoration:none;font-weight:600;font-size:11.5px;
  transition:var(--t-fast);flex-shrink:0;
}
.pp-toc a:hover{background:var(--c-primary-bg);color:var(--c-primary-l);border-color:var(--c-primary-d)}
.pp-toc a.active{background:var(--c-primary);color:var(--c-950);border-color:var(--c-primary)}
.pp-toc a.legend{background:var(--surface-elevated);color:var(--t-strong);border-color:var(--line-strong)}

/* ============================== PAGE WRAP =============================== */
.mg-wrap{max-width:1320px;margin:0 auto;padding:0 var(--sp-6) var(--sp-9)}

/* ============================== SECTION MARKER ========================== */
.pp-section{
  /* Issue 3 fix — anchor lands below sticky chrome. */
  scroll-margin-top:var(--scroll-pad);
  margin:var(--sp-9) 0 var(--sp-5);padding:var(--sp-3) 0;
  border-top:1px solid var(--line);
  display:flex;align-items:flex-end;gap:var(--sp-4);flex-wrap:wrap;
}
.pp-section .num{
  font-size:11px;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;
  color:var(--c-primary);background:var(--c-primary-bg);
  border:1px solid rgba(34,211,238,.3);
  padding:3px 9px;border-radius:var(--r-sm);
}
.pp-section .ttl{
  font-size:18px;font-weight:800;letter-spacing:-.2px;color:var(--t-strong);
  margin:0;line-height:1.2;flex:1;min-width:240px;
}
.pp-section .sub{
  font-size:13px;color:var(--t-muted);margin:0;line-height:1.5;
  flex:1;min-width:280px;font-weight:500;
}

/* ============================== PANELS ================================== */
.mg-panel{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  margin-bottom:var(--sp-4);overflow:hidden;transition:border-color var(--t-base);
}
.mg-panel:hover{border-color:var(--line-strong)}
.mg-panel-head{
  padding:var(--sp-3) var(--sp-5);
  border-bottom:1px solid var(--line-soft);
  display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);flex-wrap:wrap;
  background:rgba(255,255,255,.02);
}
.mg-panel-head h3{
  font-size:11.5px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;
  color:var(--t-strong);margin:0;display:flex;align-items:center;gap:8px;
}
.mg-panel-head h3 .ct{
  font-size:10px;font-weight:700;letter-spacing:.3px;
  background:var(--c-primary-bg);color:var(--c-primary-l);
  border:1px solid rgba(34,211,238,.25);
  padding:2px 8px;border-radius:var(--r-pill);text-transform:none;
}
.mg-panel-head .toolbar{display:flex;align-items:center;gap:var(--sp-1);flex-shrink:0}
.mg-panel-body{padding:var(--sp-5)}
.mg-panel-foot{
  padding:var(--sp-3) var(--sp-5);
  border-top:1px solid var(--line-soft);
  background:var(--bg-soft);
  font-size:12px;color:var(--t-muted);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--sp-2);
}

/* ============================== FIELDS ================================== */
.mg-fld{display:block}
.mg-fld + .mg-fld{margin-top:var(--sp-4)}
.mg-fld > label{
  display:block;
  font-size:11.5px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;
  color:var(--t-strong);margin-bottom:6px;line-height:1.3;
}
.mg-fld > label .req{color:var(--c-danger);margin-left:3px;font-weight:800}
.mg-fld > label .opt{
  font-weight:500;color:var(--t-muted);margin-left:8px;font-size:10px;
  text-transform:none;letter-spacing:.1px;
}
.mg-fld > label .info{
  display:inline-block;width:14px;height:14px;border-radius:50%;
  background:var(--c-500);color:var(--c-950);font-size:9px;font-weight:800;
  text-align:center;line-height:14px;margin-left:4px;cursor:help;
  text-transform:none;letter-spacing:0;vertical-align:1px;
}
.mg-fld input[type=text],.mg-fld input[type=email],.mg-fld input[type=url],
.mg-fld input[type=number],.mg-fld input[type=password],.mg-fld input[type=search],
.mg-fld input[type=tel],.mg-fld input[type=date],.mg-fld input[type=time],
.mg-fld input[type=datetime-local],.mg-fld textarea,.mg-fld select{
  width:100%;padding:10px 12px;
  border:1px solid var(--line);border-radius:var(--r-md);
  background:var(--surface-sunken);color:var(--t-strong);
  font-family:var(--font);font-size:13.5px;font-weight:500;
  transition:border-color var(--t-fast),box-shadow var(--t-fast),background var(--t-fast);
  min-height:40px;
}
.mg-fld input:hover:not(:disabled),.mg-fld textarea:hover:not(:disabled),.mg-fld select:hover:not(:disabled){
  border-color:var(--line-strong);background:var(--bg-soft);
}
.mg-fld input:focus,.mg-fld textarea:focus,.mg-fld select:focus{
  outline:none;border-color:var(--c-primary);box-shadow:var(--shadow-focus);
  background:var(--surface-elevated);
}
.mg-fld input::placeholder,.mg-fld textarea::placeholder{color:var(--t-subtle);font-weight:400}
.mg-fld textarea{font-family:var(--font);line-height:1.55;resize:vertical;min-height:80px}
.mg-fld select{
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M2 4l4 4 4-4' stroke='%2394a3b8' stroke-width='1.6' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat;background-position:right 10px center;padding-right:32px;
}
.mg-fld .help{
  display:flex;gap:6px;align-items:flex-start;margin-top:6px;
  font-size:12px;color:var(--t-muted);line-height:1.45;
}
.mg-fld .help .ic{color:var(--c-primary);font-weight:800;flex-shrink:0;margin-top:1px;font-size:11px}

/* Issue 2 fix — scope .err strictly under .mg-fld so site.css collisions die. */
.mg-fld .err,.mg-fld-row .err{
  display:flex;gap:6px;align-items:flex-start;margin-top:6px;padding:0;
  font-size:12px;color:var(--c-danger);line-height:1.45;font-weight:600;
  min-height:0;background:transparent;border:none;
}
.mg-fld.is-invalid input,.mg-fld.is-invalid select,.mg-fld.is-invalid textarea{
  border-color:var(--c-danger);
  box-shadow:0 0 0 3px rgba(244,63,94,.2);
  background:rgba(244,63,94,.05);
}
.mg-fld.is-valid input,.mg-fld.is-valid select{
  border-color:var(--c-success);background:rgba(16,185,129,.05);
}
.mg-fld input:disabled,.mg-fld select:disabled,.mg-fld textarea:disabled{
  background:var(--c-900);color:var(--t-muted);cursor:not-allowed;border-color:var(--line-soft);
}

.mg-fld-row{display:grid;gap:var(--sp-4);grid-template-columns:1fr 1fr}
.mg-fld-row.three{grid-template-columns:1fr 1fr 1fr}
.mg-fld-row.lr{grid-template-columns:2fr 1fr}
.mg-fld-row.tight{gap:var(--sp-3)}

/* ============================== TITLE ROW =============================== */
.mg-title-row{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:var(--sp-5);margin-bottom:var(--sp-5);
}
.mg-title-row .title-input{
  width:100%;border:none;outline:none;background:transparent;
  font-family:var(--font);font-size:24px;font-weight:800;color:var(--t-strong);
  letter-spacing:-.4px;line-height:1.2;padding:0 0 var(--sp-1);
}
.mg-title-row .title-input::placeholder{color:var(--t-subtle);font-weight:600}
.mg-slug-row{
  display:flex;align-items:center;gap:8px;margin-top:var(--sp-3);
  padding-top:var(--sp-3);border-top:1px dashed var(--line);
}
.mg-slug-row .pre{color:var(--t-muted);font-size:12.5px;font-family:var(--font-mono);font-weight:600}
.mg-slug-row .slug-input{
  flex:1;border:none;outline:none;background:transparent;
  color:var(--c-primary-l);font-size:12.5px;font-family:var(--font-mono);font-weight:600;padding:2px 0;
  min-width:0;
}
.mg-slug-row .actions{display:flex;gap:6px;flex-shrink:0}
.mg-slug-row .actions button{
  background:var(--surface-elevated);border:1px solid var(--line);color:var(--t);
  font-size:11px;font-weight:600;padding:6px 11px;border-radius:var(--r-sm);cursor:pointer;
  font-family:inherit;transition:var(--t-fast);min-height:30px;
}
.mg-slug-row .actions button:hover{border-color:var(--c-primary);color:var(--c-primary-l)}

/* ============================== BUTTONS ================================= */
.mg-btn{
  display:inline-flex;align-items:center;gap:6px;justify-content:center;
  padding:9px 14px;min-height:36px;
  border-radius:var(--r-md);
  font-family:var(--font);font-size:13px;font-weight:600;letter-spacing:.1px;line-height:1.2;
  cursor:pointer;border:1px solid transparent;text-decoration:none;
  transition:background var(--t-fast),border-color var(--t-fast),color var(--t-fast),box-shadow var(--t-fast),transform var(--t-fast);
  white-space:nowrap;
}
.mg-btn:active{transform:translateY(1px)}
.mg-btn-sm{padding:6px 11px;font-size:12px;border-radius:var(--r-sm);min-height:30px}
.mg-btn-lg{padding:12px 22px;font-size:14px;min-height:44px}
.mg-btn-primary{
  background:var(--c-primary);color:var(--c-950);border-color:var(--c-primary);
  box-shadow:0 1px 2px rgba(0,0,0,.3);
}
.mg-btn-primary:hover{background:var(--c-primary-l);border-color:var(--c-primary-l);box-shadow:0 4px 12px rgba(34,211,238,.3)}
.mg-btn-default{
  background:var(--surface-elevated);color:var(--t-strong);border-color:var(--line-strong);
}
.mg-btn-default:hover{border-color:var(--c-primary);color:var(--c-primary-l);background:var(--c-primary-bg)}
.mg-btn-ghost{background:transparent;color:var(--t-muted);border-color:transparent}
.mg-btn-ghost:hover{background:rgba(255,255,255,.06);color:var(--t-strong)}
.mg-btn-danger{
  background:var(--c-danger);color:#fff;border-color:var(--c-danger);
  box-shadow:0 1px 2px rgba(0,0,0,.3);
}
.mg-btn-danger:hover{background:var(--c-danger-d);border-color:var(--c-danger-d);box-shadow:0 4px 12px rgba(244,63,94,.3)}
.mg-btn:disabled,.mg-btn[aria-disabled=true]{opacity:.5;cursor:not-allowed;pointer-events:none}
.mg-btn:focus-visible{outline:none;box-shadow:var(--shadow-focus)}

/* ============================== STATUS PILLS ============================ */
.mg-pill-status{
  display:inline-flex;align-items:center;gap:6px;
  padding:3px 10px;border-radius:var(--r-pill);
  font-size:10px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;
  line-height:1.5;white-space:nowrap;border:1px solid;
}
.mg-pill-status::before{content:'';width:6px;height:6px;border-radius:50%}
.mg-pill-status.draft{background:#475569;color:#f1f5f9;border-color:#64748b}
.mg-pill-status.draft::before{background:#cbd5e1}
.mg-pill-status.review{background:#78350f;color:#fef3c7;border-color:#a16207}
.mg-pill-status.review::before{background:#fbbf24;box-shadow:0 0 6px rgba(251,191,36,.6)}
.mg-pill-status.published{background:#064e3b;color:#a7f3d0;border-color:#047857}
.mg-pill-status.published::before{background:#10b981;box-shadow:0 0 6px rgba(16,185,129,.6)}
.mg-pill-status.archived{background:#334155;color:#cbd5e1;border-color:#475569}
.mg-pill-status.archived::before{background:#94a3b8}
.mg-pill-status.error{background:#881337;color:#fecdd3;border-color:#9f1239}
.mg-pill-status.error::before{background:#f43f5e;box-shadow:0 0 6px rgba(244,63,94,.6)}

/* ============================== PAGE HEAD =============================== */
.mg-page-head{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:var(--sp-5) var(--sp-6);margin-bottom:var(--sp-4);
}
.mg-page-head-row{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--sp-5);margin-top:var(--sp-2);flex-wrap:wrap}
.mg-page-head-actions{display:flex;gap:6px;flex-shrink:0;flex-wrap:wrap}
.mg-crumbs{font-size:12px;color:var(--t-muted);font-weight:500}
.mg-crumbs a{color:var(--c-primary-l);text-decoration:none;font-weight:600}
.mg-crumbs a:hover{text-decoration:underline}
.mg-crumbs .sep{margin:0 6px;color:var(--t-subtle)}
.mg-crumbs span[aria-current=page]{color:var(--t-strong);font-weight:700}
.mg-page-head h1{font-size:24px;font-weight:800;color:var(--t-strong);letter-spacing:-.4px;line-height:1.2;margin:0 0 4px}
.mg-page-lede{font-size:13.5px;color:var(--t-muted);line-height:1.5;margin:0;font-weight:500}
.mg-page-lede strong{color:var(--t-strong);font-weight:700}

/* ============================== EDIT GRID =============================== */
.mg-edit-grid{display:grid;grid-template-columns:1fr 320px;gap:var(--sp-5);align-items:flex-start}
.mg-edit-main{min-width:0}
.mg-edit-side{position:sticky;top:calc(var(--scroll-pad) + 4px)}

/* ============================== SIDE CARDS ============================== */
.mg-side-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  margin-bottom:var(--sp-3);overflow:hidden;
}
.mg-side-card .head{
  padding:10px var(--sp-4);border-bottom:1px solid var(--line-soft);
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  background:rgba(255,255,255,.02);
}
.mg-side-card .head h4{
  font-size:10.5px;font-weight:800;letter-spacing:.7px;text-transform:uppercase;
  color:var(--t-strong);margin:0;
}
.mg-side-card .body{padding:var(--sp-4)}
.mg-side-card .row{
  display:flex;justify-content:space-between;align-items:center;gap:8px;
  padding:7px 0;border-top:1px solid var(--line-soft);font-size:12.5px;
}
.mg-side-card .row:first-child{border-top:none;padding-top:0}
.mg-side-card .row .k{
  color:var(--t-muted);font-size:10.5px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;
}
.mg-side-card .row .v{color:var(--t-strong);font-weight:600;text-align:right;font-size:12.5px}

/* ============================== STATUS RADIO CARDS ====================== */
.mg-status-pick{display:flex;flex-direction:column;gap:6px}
.mg-status-pick label{
  display:flex;gap:10px;padding:9px 11px;
  border:1px solid var(--line);border-radius:var(--r-md);
  background:var(--surface-sunken);cursor:pointer;transition:var(--t-fast);align-items:flex-start;margin:0;
  min-height:54px;
}
.mg-status-pick label:hover{border-color:var(--c-primary);background:var(--c-primary-bg)}
.mg-status-pick label:has(input:checked){
  border-color:var(--c-primary);background:var(--c-primary-bg-strong);
  box-shadow:var(--shadow-focus);
}
.mg-status-pick input{margin-top:3px;flex-shrink:0;accent-color:var(--c-primary);width:16px;height:16px}
.mg-status-pick span.l{
  display:flex;align-items:center;gap:6px;
  font-size:12.5px;font-weight:700;color:var(--t-strong);margin-bottom:3px;
}
.mg-status-pick span.h{display:block;font-size:11px;font-weight:500;color:var(--t-muted);line-height:1.4}

/* ============================== CHIPS / TAGS ============================ */
.mg-chips{
  display:flex;flex-wrap:wrap;gap:5px;
  padding:7px;border:1px solid var(--line);border-radius:var(--r-md);
  background:var(--surface-sunken);min-height:42px;align-items:center;
  transition:border-color var(--t-fast),box-shadow var(--t-fast);
}
.mg-chips:focus-within{border-color:var(--c-primary);box-shadow:var(--shadow-focus)}
.mg-chips .chip{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--c-primary-bg);color:var(--c-primary-l);
  border:1px solid rgba(34,211,238,.3);
  padding:4px 4px 4px 10px;border-radius:var(--r-pill);
  font-size:12px;font-weight:600;
}
.mg-chips .chip button{
  /* Issue 5 fix — bigger hit area while keeping glyph small. */
  background:transparent;border:none;color:var(--c-primary-l);
  font-size:14px;cursor:pointer;padding:0;line-height:1;width:24px;height:24px;
  border-radius:50%;display:inline-flex;align-items:center;justify-content:center;
}
.mg-chips .chip button:hover{background:var(--c-primary);color:var(--c-950)}
.mg-chips input{
  flex:1;border:none;outline:none;background:transparent;
  font-size:12.5px;min-width:120px;padding:4px;font-family:var(--font);color:var(--t-strong);
}
.mg-chips input::placeholder{color:var(--t-subtle)}

/* ============================== RADIO STRIP ============================= */
.mg-radio-strip{
  display:inline-flex;border:1px solid var(--line);border-radius:var(--r-md);
  overflow:hidden;background:var(--surface-sunken);
}
.mg-radio-strip label{
  margin:0;padding:9px 16px;cursor:pointer;background:transparent;
  font-size:12.5px;font-weight:600;color:var(--t-muted);
  border-right:1px solid var(--line);transition:var(--t-fast);
  text-transform:none;letter-spacing:0;min-height:40px;display:inline-flex;align-items:center;
}
.mg-radio-strip label:last-child{border-right:none}
.mg-radio-strip input{position:absolute;opacity:0;pointer-events:none}
.mg-radio-strip label:hover{background:var(--c-primary-bg);color:var(--c-primary-l)}
.mg-radio-strip label:has(input:checked){background:var(--c-primary);color:var(--c-950)}

/* ============================== TOGGLE SWITCH =========================== */
.mg-switch{
  position:relative;display:inline-flex;align-items:center;cursor:pointer;
  font-size:12.5px;color:var(--t);gap:10px;font-weight:500;min-height:32px;
}
.mg-switch input{position:absolute;opacity:0;pointer-events:none}
.mg-switch .track{
  width:36px;height:20px;background:var(--c-700);border-radius:var(--r-pill);
  position:relative;transition:background var(--t-base);flex-shrink:0;
  border:1px solid var(--line-strong);
}
.mg-switch .track::after{
  content:'';position:absolute;top:1px;left:1px;width:16px;height:16px;
  background:var(--c-300);border-radius:50%;transition:transform var(--t-base);
  box-shadow:0 1px 3px rgba(0,0,0,.4);
}
.mg-switch input:checked + .track{background:var(--c-primary);border-color:var(--c-primary-d)}
.mg-switch input:checked + .track::after{transform:translateX(14px);background:#fff}
.mg-switch:has(input:disabled){opacity:.5;cursor:not-allowed}
.mg-switch:focus-within .track{box-shadow:var(--shadow-focus)}

/* ============================== CONDITIONAL ============================= */
.pp-conditional{
  margin-top:var(--sp-2);padding:var(--sp-4);
  background:var(--c-primary-bg);
  border:1px dashed rgba(34,211,238,.4);border-radius:var(--r-md);
}
.pp-conditional[hidden]{display:none}

/* ============================== BANNERS ================================= */
.pp-banner{
  display:flex;align-items:flex-start;gap:10px;
  padding:11px 14px;border-radius:var(--r-md);font-size:12.5px;margin-bottom:var(--sp-4);
  border:1px solid;font-weight:500;line-height:1.5;
}
.pp-banner .ic{font-size:15px;flex-shrink:0;line-height:1.3;margin-top:1px}
.pp-banner.info{background:rgba(34,211,238,.1);color:#a5f3fc;border-color:rgba(34,211,238,.3)}
.pp-banner.warn{background:rgba(251,191,36,.1);color:#fde68a;border-color:rgba(251,191,36,.3)}
.pp-banner.success{background:rgba(16,185,129,.1);color:#6ee7b7;border-color:rgba(16,185,129,.3)}
.pp-banner.error{background:rgba(244,63,94,.1);color:#fda4af;border-color:rgba(244,63,94,.3)}
.pp-banner strong{font-weight:700;color:var(--t-strong)}

/* ============================== STICKY SAVE BAR ========================= */
.mg-sticky-actions{
  position:sticky;bottom:0;z-index:50;
  background:linear-gradient(180deg,transparent 0%,var(--bg) 18%);
  padding-top:var(--sp-3);margin-top:var(--sp-6);
}
.mg-sticky-actions-inner{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:var(--sp-3) var(--sp-5);display:flex;justify-content:space-between;align-items:center;gap:var(--sp-4);
  box-shadow:var(--shadow-lg);flex-wrap:wrap;
}
.mg-sticky-actions-inner .right{display:flex;gap:8px;flex-wrap:wrap}

/* ============================== SAVE STATE ============================== */
.mg-save-state{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:600}
.mg-save-state .dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.mg-save-state.idle .dot{background:var(--c-500)}
.mg-save-state.idle{color:var(--t-muted)}
.mg-save-state.saving .dot{background:var(--c-warn);animation:pulse 1.4s infinite}
.mg-save-state.saving{color:#fde68a}
.mg-save-state.saved .dot{background:var(--c-success);box-shadow:0 0 0 4px rgba(16,185,129,.2)}
.mg-save-state.saved{color:#6ee7b7}
.mg-save-state.conflict .dot{background:var(--c-warn)}
.mg-save-state.conflict{color:#fde68a}
.mg-save-state.error .dot{background:var(--c-danger)}
.mg-save-state.error{color:#fda4af}
@keyframes pulse{50%{opacity:.4}}

/* ============================== EDITOR ================================== */
.mg-editor{border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface);overflow:hidden}
.mg-editor-toolbar{
  display:flex;flex-wrap:wrap;gap:0;padding:5px;background:var(--bg-soft);
  border-bottom:1px solid var(--line);align-items:center;
}
.mg-editor-toolbar .group{
  display:flex;gap:1px;padding:0 5px;border-right:1px solid var(--line);
}
.mg-editor-toolbar .group:last-child{border-right:none;margin-left:auto}
.mg-editor-toolbar button{
  background:transparent;border:1px solid transparent;color:var(--t);
  /* Issue 5 fix — was 28px; now 32px hit. */
  width:32px;height:32px;border-radius:var(--r-sm);cursor:pointer;
  font-size:13px;font-weight:600;display:inline-flex;align-items:center;justify-content:center;
  transition:var(--t-fast);
}
.mg-editor-toolbar button:hover{background:var(--surface-elevated);border-color:var(--line);color:var(--t-strong)}
.mg-editor-toolbar select{
  background:var(--surface-elevated);border:1px solid var(--line);border-radius:var(--r-sm);
  padding:5px 8px;font-size:12px;color:var(--t);font-weight:600;cursor:pointer;font-family:var(--font);
}
.mg-editor-area{
  padding:var(--sp-4) var(--sp-5);min-height:var(--editor-min,180px);
  font-size:14px;line-height:1.6;color:var(--t-strong);background:var(--surface);
}
.mg-editor-area p{margin:0 0 10px}
.mg-editor-area p:last-child{margin-bottom:0}
.mg-editor-foot{
  padding:7px var(--sp-4);border-top:1px solid var(--line-soft);background:var(--bg-soft);
  display:flex;justify-content:space-between;align-items:center;font-size:11.5px;color:var(--t-muted);
}
.mg-editor-foot .stats{display:flex;gap:14px}
.mg-editor-foot strong{color:var(--t-strong);font-weight:700}

/* ============================== VERTICAL TABS =========================== */
.mg-vtabs{
  display:grid;grid-template-columns:220px 1fr;
  border:1px solid var(--line);border-radius:var(--r-lg);
  background:var(--surface);overflow:hidden;
}
.mg-vtabs-nav{background:var(--bg-soft);border-right:1px solid var(--line);padding:10px}
.mg-vtabs-nav button{
  display:flex;width:100%;padding:9px 12px;background:transparent;border:none;
  border-radius:var(--r-sm);font-size:12.5px;font-weight:600;color:var(--t);
  cursor:pointer;text-align:left;margin-bottom:2px;align-items:center;gap:8px;
  transition:var(--t-fast);font-family:var(--font);justify-content:space-between;min-height:36px;
}
.mg-vtabs-nav button:hover{background:var(--surface-elevated);color:var(--t-strong)}
.mg-vtabs-nav button[aria-selected=true]{background:var(--c-primary);color:var(--c-950)}
.mg-vtabs-nav button .badge{
  font-size:10px;font-weight:800;padding:2px 7px;border-radius:var(--r-pill);
  background:var(--c-primary-bg);color:var(--c-primary-l);
}
.mg-vtabs-nav button[aria-selected=true] .badge{background:rgba(2,6,23,.4);color:#fff}
.mg-vtabs-pane{padding:var(--sp-5)}
.mg-vtabs-pane[hidden]{display:none}

/* ============================== PARAGRAPHS ============================== */
.mg-paragraphs{display:flex;flex-direction:column;gap:8px}
.mg-paragraph{border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface-sunken);overflow:hidden;transition:border-color var(--t-fast)}
.mg-paragraph:hover{border-color:var(--line-strong)}
.mg-paragraph.is-collapsed .mg-paragraph-body{display:none}
.mg-paragraph-head{
  display:flex;align-items:center;gap:8px;padding:10px 12px;
  background:rgba(255,255,255,.02);border-bottom:1px solid var(--line-soft);cursor:grab;
}
.mg-paragraph.is-collapsed .mg-paragraph-head{border-bottom:none}
.mg-paragraph-head .grip{color:var(--t-subtle);font-size:13px;cursor:grab;font-weight:800;width:16px;flex-shrink:0}
.mg-paragraph-head .label{flex:1;font-size:12.5px;font-weight:700;color:var(--t-strong);min-width:0}
.mg-paragraph-head .label small{display:block;font-size:11px;font-weight:500;color:var(--t-muted);margin-top:1px}
.mg-paragraph-head .actions{display:flex;gap:2px;flex-shrink:0}
.mg-paragraph-head .actions button{
  background:transparent;border:none;color:var(--t-muted);
  /* Issue 5 fix — bumped from 26 to 32. */
  width:32px;height:32px;border-radius:var(--r-sm);cursor:pointer;
  font-size:13px;display:inline-flex;align-items:center;justify-content:center;transition:var(--t-fast);
}
.mg-paragraph-head .actions button:hover{background:var(--surface-elevated);color:var(--t-strong)}
.mg-paragraph-head .actions .danger:hover{background:rgba(244,63,94,.15);color:var(--c-danger)}
.mg-paragraph-body{padding:var(--sp-4);background:var(--surface)}
.mg-paragraph-add{
  margin-top:var(--sp-2);display:flex;gap:6px;flex-wrap:wrap;padding:var(--sp-3);
  border:1px dashed var(--line);border-radius:var(--r-md);background:var(--surface-sunken);
}
.mg-paragraph-add .add-btn{
  background:var(--surface-elevated);border:1px solid var(--line);color:var(--t-strong);
  padding:7px 11px;border-radius:var(--r-sm);font-size:12px;font-weight:600;cursor:pointer;
  display:inline-flex;align-items:center;gap:6px;font-family:var(--font);
  transition:var(--t-fast);min-height:32px;
}
.mg-paragraph-add .add-btn:hover{border-color:var(--c-primary);color:var(--c-primary-l);background:var(--c-primary-bg)}
.mg-paragraph-add .add-btn .plus{
  width:14px;height:14px;background:var(--c-primary);color:var(--c-950);
  border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;
}

/* ============================== MULTI-VALUE ============================= */
.mg-multi{display:flex;flex-direction:column;gap:6px}
.mg-multi-row{display:flex;gap:8px;align-items:center}
.mg-multi-row .grip{color:var(--t-subtle);font-size:14px;cursor:grab;flex-shrink:0;width:24px;text-align:center;font-weight:800}
.mg-multi-row > .mg-fld{flex:1;margin:0}
.mg-multi-row .rm{
  background:rgba(244,63,94,.15);border:1px solid rgba(244,63,94,.3);color:#fda4af;
  width:38px;height:40px;border-radius:var(--r-sm);cursor:pointer;font-size:14px;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;transition:var(--t-fast);
}
.mg-multi-row .rm:hover{background:var(--c-danger);color:#fff;border-color:var(--c-danger)}

/* ============================== UPLOAD ================================== */
.mg-upload{
  border:2px dashed var(--line-strong);border-radius:var(--r-lg);padding:var(--sp-6);
  background:var(--surface-sunken);text-align:center;transition:var(--t-base);cursor:pointer;
}
.mg-upload:hover,.mg-upload.is-dragging{border-color:var(--c-primary);background:var(--c-primary-bg)}
.mg-upload .icn{font-size:28px;color:var(--c-primary);margin-bottom:6px;display:block}
.mg-upload .ttl{font-size:13.5px;font-weight:700;color:var(--t-strong);margin-bottom:4px}
.mg-upload .sub{font-size:11.5px;color:var(--t-muted)}
.mg-upload .browse{color:var(--c-primary-l);text-decoration:underline;font-weight:700}
.mg-upload-list{margin-top:var(--sp-3);display:flex;flex-direction:column;gap:6px}
.mg-upload-item{
  display:flex;align-items:center;gap:10px;padding:9px 11px;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);
}
.mg-upload-item .icn{font-size:16px;color:var(--c-primary);flex-shrink:0}
.mg-upload-item .info{flex:1;min-width:0}
.mg-upload-item .nm{font-size:12.5px;font-weight:700;color:var(--t-strong);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mg-upload-item .meta{font-size:11px;color:var(--t-muted);margin-top:1px}
.mg-upload-item .progress{width:84px;height:4px;background:var(--c-700);border-radius:var(--r-pill);overflow:hidden;flex-shrink:0}
.mg-upload-item .progress-bar{height:100%;background:linear-gradient(90deg,var(--c-primary) 0%,var(--c-primary-l) 100%);border-radius:var(--r-pill)}
.mg-upload-item .rm{
  background:transparent;border:none;color:var(--t-muted);font-size:14px;cursor:pointer;
  width:28px;height:28px;flex-shrink:0;border-radius:var(--r-sm);
}
.mg-upload-item .rm:hover{background:rgba(244,63,94,.15);color:var(--c-danger)}

/* ============================== AUTOCOMPLETE ============================ */
.mg-autocomplete{position:relative}
.mg-autocomplete-results{
  position:absolute;top:100%;left:0;right:0;z-index:20;
  background:var(--surface-elevated);border:1px solid var(--line);border-radius:var(--r-md);
  margin-top:4px;box-shadow:var(--shadow-xl);overflow:hidden;
  max-height:280px;overflow-y:auto;
}
.mg-autocomplete-results button{
  display:flex;width:100%;padding:9px 14px;background:transparent;border:none;
  text-align:left;font-size:12.5px;color:var(--t);cursor:pointer;
  border-bottom:1px solid var(--line-soft);transition:var(--t-fast);font-family:var(--font);
  align-items:center;gap:10px;min-height:40px;
}
.mg-autocomplete-results button:hover,.mg-autocomplete-results button:focus{
  background:var(--c-primary-bg);color:var(--t-strong);outline:none;
}
.mg-autocomplete-results button:last-child{border-bottom:none}
.mg-autocomplete-results .av{
  width:24px;height:24px;border-radius:50%;background:var(--c-primary);color:var(--c-950);
  display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;flex-shrink:0;
}
.mg-autocomplete-results .meta{margin-left:auto;color:var(--t-muted);font-size:11px;font-weight:500}

/* ============================== COMPOSITE =============================== */
.mg-composite{
  border:1px solid var(--line);border-radius:var(--r-md);
  background:var(--bg-soft);padding:var(--sp-4);
}
.mg-composite-head{
  font-size:10.5px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;
  color:var(--t-muted);margin-bottom:10px;
}

/* ============================== MATRIX ================================== */
.mg-matrix{
  width:100%;border-collapse:separate;border-spacing:0;
  border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;
  background:var(--surface);font-size:12.5px;
}
.mg-matrix thead th{
  background:var(--c-950);color:var(--t-strong);
  font-size:10.5px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;
  padding:11px;text-align:center;border-bottom:1px solid var(--line);
}
.mg-matrix thead th:first-child{text-align:left}
.mg-matrix tbody tr.section td{
  background:var(--bg-soft);font-weight:800;color:var(--t-strong);
  font-size:10.5px;text-transform:uppercase;letter-spacing:.4px;padding:7px 12px;
}
.mg-matrix tbody td{padding:8px 12px;border-top:1px solid var(--line-soft)}
.mg-matrix tbody td.perm{color:var(--t-strong);font-weight:600}
.mg-matrix tbody td.perm small{display:block;font-size:11px;color:var(--t-muted);font-weight:400;margin-top:1px}
.mg-matrix tbody td.cell{text-align:center}
.mg-matrix tbody td.cell input[type=checkbox]{accent-color:var(--c-primary);width:18px;height:18px;cursor:pointer}
.mg-matrix tbody tr:hover td:not(.cell){background:var(--surface-elevated)}

/* ============================== MODAL =================================== */
.mg-modal-overlay{
  position:fixed;inset:0;background:rgba(2,6,23,.7);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:200;
  display:flex;align-items:center;justify-content:center;padding:var(--sp-4);
}
.mg-modal-overlay[hidden]{display:none}
.mg-modal{
  background:var(--surface-elevated);border:1px solid var(--line);
  border-radius:var(--r-xl);width:min(440px,100%);box-shadow:var(--shadow-2xl);overflow:hidden;
}
.mg-modal-head{
  display:flex;align-items:center;gap:12px;padding:var(--sp-5) var(--sp-5) var(--sp-3);
  border-bottom:1px solid var(--line-soft);
}
.mg-modal-head .icn{
  width:36px;height:36px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;
}
.mg-modal-head.danger .icn{background:rgba(244,63,94,.15);color:#fda4af}
.mg-modal-head.warn .icn{background:rgba(251,191,36,.15);color:#fde68a}
.mg-modal-head.info .icn{background:var(--c-primary-bg);color:var(--c-primary-l)}
.mg-modal-head h3{font-size:15px;font-weight:800;color:var(--t-strong);margin:0;letter-spacing:-.1px}
.mg-modal-body{padding:var(--sp-4) var(--sp-5);font-size:13px;line-height:1.55;color:var(--t)}
.mg-modal-body strong{color:var(--t-strong);font-weight:700}
.mg-modal-foot{
  display:flex;justify-content:flex-end;gap:8px;padding:var(--sp-3) var(--sp-5) var(--sp-5);
  background:var(--bg-soft);border-top:1px solid var(--line-soft);
}

/* ============================== WIZARD ================================== */
.mg-wizard{
  display:flex;justify-content:space-between;gap:8px;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:var(--sp-4) var(--sp-5);margin-bottom:var(--sp-4);
}
.mg-wizard-step{display:flex;align-items:center;gap:10px;flex:1;position:relative}
.mg-wizard-step::after{
  content:'';position:absolute;top:14px;right:-4px;width:calc(100% - 50px);height:2px;
  background:var(--line);z-index:0;
}
.mg-wizard-step:last-child::after{display:none}
.mg-wizard-step.is-done::after{background:var(--c-success)}
.mg-wizard-step .num{
  width:30px;height:30px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:800;background:var(--surface-sunken);color:var(--t-muted);
  border:2px solid var(--line);flex-shrink:0;z-index:1;
}
.mg-wizard-step.is-done .num{background:var(--c-success);color:var(--c-950);border-color:var(--c-success)}
.mg-wizard-step.is-done .num::before{content:'✓'}
.mg-wizard-step.is-active .num{
  background:var(--c-primary);color:var(--c-950);border-color:var(--c-primary);
  box-shadow:0 0 0 4px rgba(34,211,238,.25);
}
.mg-wizard-step .lbl{font-size:11px;font-weight:700;color:var(--t-muted);text-transform:uppercase;letter-spacing:.3px}
.mg-wizard-step.is-active .lbl{color:var(--c-primary-l)}
.mg-wizard-step.is-done .lbl{color:var(--t-strong)}

/* ============================== FILTER + BULK =========================== */
.mg-filter-bar{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:var(--sp-3) var(--sp-4);
  display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end;
}
.mg-filter-bar .field{flex:1;min-width:160px;display:flex;flex-direction:column;gap:4px}
.mg-filter-bar .field label{font-size:10px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--t-muted)}
.mg-filter-bar .field input,.mg-filter-bar .field select{
  padding:8px 11px;border:1px solid var(--line);border-radius:var(--r-sm);
  font-size:12.5px;color:var(--t-strong);font-family:var(--font);
  background:var(--surface-sunken);min-height:36px;
}
.mg-filter-bar .field input:focus,.mg-filter-bar .field select:focus{
  outline:none;border-color:var(--c-primary);box-shadow:var(--shadow-focus);
}

.mg-bulk{
  display:flex;align-items:center;gap:10px;padding:10px 14px;
  background:var(--c-primary-bg);
  border:1px solid rgba(34,211,238,.3);border-radius:var(--r-md);margin-bottom:var(--sp-2);
  font-size:12.5px;flex-wrap:wrap;
}
.mg-bulk .selected{font-weight:700;color:var(--t-strong)}
.mg-bulk .selected b{
  background:var(--c-primary);color:var(--c-950);padding:1px 8px;border-radius:var(--r-pill);
  font-size:11px;margin:0 4px;font-weight:800;
}
.mg-bulk select{
  padding:6px 10px;border:1px solid var(--line);border-radius:var(--r-sm);
  font-size:12px;font-family:var(--font);background:var(--surface);color:var(--t-strong);min-height:32px;
}

/* ============================== SPECIALISED FIELDS ====================== */
/* Slider */
.mg-slider{position:relative}
.mg-slider input[type=range]{width:100%;-webkit-appearance:none;background:transparent;height:24px;cursor:pointer}
.mg-slider input[type=range]::-webkit-slider-runnable-track{
  height:4px;background:linear-gradient(90deg,var(--c-primary) var(--val,50%),var(--line) var(--val,50%));
  border-radius:var(--r-pill);
}
.mg-slider input[type=range]::-moz-range-track{height:4px;background:var(--line);border-radius:var(--r-pill)}
.mg-slider input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;width:18px;height:18px;border-radius:50%;
  background:var(--c-primary);border:2px solid var(--c-950);
  box-shadow:0 1px 4px rgba(0,0,0,.6);margin-top:-7px;cursor:grab;
}
.mg-slider .val{
  display:inline-block;background:var(--c-primary);color:var(--c-950);
  font-size:11px;font-weight:800;font-family:var(--font-mono);
  padding:2px 9px;border-radius:var(--r-pill);margin-top:4px;
}
.mg-slider-row{display:flex;justify-content:space-between;font-size:10.5px;color:var(--t-muted);margin-top:4px}

/* Color picker */
.mg-color{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.mg-color-swatches{display:flex;gap:5px;flex-wrap:wrap}
.mg-color-swatches button{
  /* Issue 5 fix — was 26px; now 32px. */
  width:32px;height:32px;border-radius:var(--r-sm);
  border:2px solid var(--line);cursor:pointer;padding:0;transition:var(--t-fast);position:relative;
}
.mg-color-swatches button:hover{transform:scale(1.1);border-color:var(--c-primary)}
.mg-color-swatches button[aria-checked=true]{
  border-color:var(--t-strong);box-shadow:0 0 0 2px var(--surface),0 0 0 4px var(--c-primary);
}
.mg-color-swatches button[aria-checked=true]::after{
  content:'✓';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:800;font-size:14px;text-shadow:0 1px 2px rgba(0,0,0,.6);
}
.mg-color-input{display:flex;align-items:center;gap:6px}
.mg-color-input input[type=color]{
  width:36px;height:36px;border:1px solid var(--line);border-radius:var(--r-sm);
  padding:2px;cursor:pointer;background:var(--surface-sunken);
}
.mg-color-input input[type=text]{width:104px;font-family:var(--font-mono)}

/* Image with focal point */
.mg-focal{
  position:relative;border-radius:var(--r-md);overflow:hidden;
  border:1px solid var(--line);background:var(--c-950);
  width:100%;max-width:480px;aspect-ratio:16/9;
}
.mg-focal-img{
  position:absolute;inset:0;
  background:linear-gradient(135deg,#1e3a5f 0%,#0a2240 50%,#062940 100%);
  display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.4);
  font-family:var(--font-mono);font-size:12px;
}
.mg-focal-cross{
  position:absolute;width:30px;height:30px;border:2px solid #fff;border-radius:50%;
  cursor:grab;transform:translate(-50%,-50%);
  box-shadow:0 0 0 1px rgba(0,0,0,.4),0 0 0 9999px rgba(0,0,0,.5);
  background:rgba(34,211,238,.5);
}
.mg-focal-cross::before,.mg-focal-cross::after{content:'';position:absolute;background:#fff}
.mg-focal-cross::before{left:50%;top:-12px;bottom:-12px;width:1.5px;transform:translateX(-50%)}
.mg-focal-cross::after{top:50%;left:-12px;right:-12px;height:1.5px;transform:translateY(-50%)}

/* Password strength */
.mg-password{position:relative}
.mg-password input{padding-right:42px;font-family:var(--font-mono)}
.mg-password .toggle{
  position:absolute;right:10px;top:8px;background:transparent;border:none;
  color:var(--t-muted);cursor:pointer;font-size:14px;width:28px;height:28px;
  border-radius:var(--r-sm);
}
.mg-password .toggle:hover{background:rgba(255,255,255,.06);color:var(--t-strong)}
.mg-password-strength{margin-top:6px}
.mg-password-bars{display:flex;gap:4px}
.mg-password-bars span{flex:1;height:4px;background:var(--c-700);border-radius:var(--r-pill);transition:var(--t-base)}
.mg-password-strength[data-level="1"] .mg-password-bars span:nth-child(-n+1){background:var(--c-danger)}
.mg-password-strength[data-level="2"] .mg-password-bars span:nth-child(-n+2){background:var(--c-warn)}
.mg-password-strength[data-level="3"] .mg-password-bars span:nth-child(-n+3){background:var(--c-success)}
.mg-password-strength[data-level="4"] .mg-password-bars span{background:var(--c-success)}
.mg-password-strength .label{font-size:11px;color:var(--t-muted);margin-top:4px;font-weight:600}
.mg-password-strength[data-level="1"] .label{color:#fda4af}
.mg-password-strength[data-level="2"] .label{color:#fde68a}
.mg-password-strength[data-level="3"] .label,.mg-password-strength[data-level="4"] .label{color:#6ee7b7}

/* Code editor */
.mg-code{border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;font-family:var(--font-mono)}
.mg-code-head{
  display:flex;align-items:center;justify-content:space-between;padding:8px 12px;
  background:var(--surface-elevated);border-bottom:1px solid var(--line);
  font-size:11px;font-weight:600;color:var(--t-muted);
}
.mg-code-head select{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);
  padding:4px 8px;font-size:11px;font-family:var(--font);color:var(--t);min-height:28px;
}
.mg-code-body{display:flex;background:var(--c-950);color:var(--t)}
.mg-code-gutter{
  background:var(--c-900);color:var(--t-muted);padding:12px 10px;
  font-size:12px;line-height:1.7;text-align:right;font-family:var(--font-mono);
  user-select:none;flex-shrink:0;border-right:1px solid var(--line-soft);
}
.mg-code-area{
  flex:1;padding:12px 14px;color:var(--t-strong);font-size:12.5px;line-height:1.7;
  font-family:var(--font-mono);background:var(--c-950);
  border:none;outline:none;resize:vertical;min-height:140px;
}

/* Char counter */
.mg-char-counter{display:flex;justify-content:space-between;font-size:11px;color:var(--t-muted);margin-top:4px;gap:14px;align-items:flex-start}
.mg-char-counter .count{font-family:var(--font-mono);font-weight:600;flex-shrink:0;color:var(--t)}
.mg-char-counter .count.warn{color:#fde68a}
.mg-char-counter .count.danger{color:#fda4af}

/* OTP */
.mg-otp{display:flex;gap:8px}
.mg-otp input{
  width:46px;height:52px;text-align:center;font-family:var(--font-mono);
  font-size:20px;font-weight:800;color:var(--t-strong);
  border:1.5px solid var(--line);border-radius:var(--r-md);background:var(--surface-sunken);
  transition:var(--t-fast);
}
.mg-otp input:focus{outline:none;border-color:var(--c-primary);box-shadow:var(--shadow-focus);background:var(--surface-elevated)}

/* Number stepper */
.mg-stepper{display:inline-flex;border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;background:var(--surface-sunken)}
.mg-stepper button{
  background:transparent;border:none;width:36px;height:40px;cursor:pointer;
  font-size:14px;font-weight:700;color:var(--t);transition:var(--t-fast);
}
.mg-stepper button:hover{background:var(--c-primary-bg);color:var(--c-primary-l)}
.mg-stepper input{
  width:64px;text-align:center;border:none;border-left:1px solid var(--line);border-right:1px solid var(--line);
  background:transparent;font-size:13px;font-weight:700;color:var(--t-strong);font-family:var(--font-mono);
}
.mg-stepper input:focus{outline:none;background:var(--c-primary-bg)}

/* Phone */
.mg-phone{display:flex;border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;background:var(--surface-sunken)}
.mg-phone .country{
  display:flex;align-items:center;gap:6px;padding:0 10px;background:var(--surface-elevated);
  border-right:1px solid var(--line);font-size:13px;cursor:pointer;border:none;color:var(--t-strong);font-family:var(--font);
}
.mg-phone .flag{font-size:16px}
.mg-phone .code{font-family:var(--font-mono);font-weight:600;color:var(--t-strong)}
.mg-phone input{
  flex:1;border:none;outline:none;padding:10px 12px;font-size:13.5px;font-family:var(--font-mono);
  color:var(--t-strong);background:transparent;
}

/* ============================== LAYOUT VARIANTS ========================= */
/* Settings (no sidebar) */
.mg-settings{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;
}
.mg-settings-section{padding:var(--sp-5) var(--sp-6);border-bottom:1px solid var(--line-soft)}
.mg-settings-section:last-child{border-bottom:none}
.mg-settings-section h3{font-size:14px;font-weight:800;color:var(--t-strong);margin:0 0 4px;letter-spacing:-.1px}
.mg-settings-section p.lede{font-size:12.5px;color:var(--t-muted);margin:0 0 var(--sp-4);line-height:1.5}
.mg-settings-section .mg-fld-row.lr{grid-template-columns:1fr 2fr;gap:var(--sp-5);align-items:flex-start}

/* Auth card */
.mg-auth-wrap{
  background:radial-gradient(ellipse at top, rgba(34,211,238,.1) 0%, transparent 60%);
  padding:var(--sp-7) var(--sp-4);border-radius:var(--r-lg);
}
.mg-auth-card{
  background:var(--surface-elevated);border:1px solid var(--line);
  border-radius:var(--r-xl);padding:var(--sp-7);
  max-width:420px;margin:0 auto;box-shadow:var(--shadow-xl);
}
.mg-auth-card .brand-mark{
  width:48px;height:48px;border-radius:var(--r-md);
  background:linear-gradient(135deg,var(--c-primary) 0%,var(--c-primary-d) 100%);
  color:var(--c-950);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:800;
  margin-bottom:var(--sp-4);
}
.mg-auth-card h2{font-size:22px;font-weight:800;color:var(--t-strong);margin:0 0 6px;letter-spacing:-.3px}
.mg-auth-card p.lede{font-size:13px;color:var(--t-muted);margin:0 0 var(--sp-5);line-height:1.5}
.mg-auth-card p.lede a{color:var(--c-primary-l);text-decoration:none;font-weight:700}
.mg-auth-card .divider{
  display:flex;align-items:center;gap:10px;margin:var(--sp-4) 0;color:var(--t-subtle);font-size:11px;font-weight:600;
}
.mg-auth-card .divider::before,.mg-auth-card .divider::after{content:'';flex:1;height:1px;background:var(--line)}
.mg-auth-card .alt{margin-top:var(--sp-5);text-align:center;font-size:12px;color:var(--t-muted)}
.mg-auth-card .alt a{color:var(--c-primary-l);text-decoration:none;font-weight:700}

/* Inline edit */
.mg-inline-edit{
  display:inline-flex;align-items:center;gap:6px;padding:5px 10px;
  border-radius:var(--r-sm);cursor:pointer;transition:var(--t-fast);
}
.mg-inline-edit:hover{background:var(--c-primary-bg)}
.mg-inline-edit.is-editing{background:var(--surface-sunken);border:1px solid var(--c-primary);padding:4px 9px;box-shadow:var(--shadow-focus)}
.mg-inline-edit .display{font-weight:600;color:var(--t-strong)}
.mg-inline-edit .pencil{opacity:.5;font-size:11px;transition:var(--t-fast);color:var(--t-muted)}
.mg-inline-edit:hover .pencil{opacity:1;color:var(--c-primary-l)}
.mg-inline-edit input{
  border:none;outline:none;background:transparent;font:inherit;color:var(--t-strong);
  font-weight:600;width:180px;
}

/* Read-only summary */
.mg-summary{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:var(--sp-5);
}
.mg-summary dl{display:grid;grid-template-columns:140px 1fr;gap:var(--sp-3) var(--sp-5);margin:0}
.mg-summary dt{font-size:10.5px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--t-muted);margin:0;padding-top:2px}
.mg-summary dd{margin:0;font-size:13px;color:var(--t-strong);font-weight:500;line-height:1.5}

/* ============================== TOKENS BLOCK ============================ */
.pp-tokens{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:var(--sp-5);margin-bottom:var(--sp-4);
}
.pp-tokens-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-4)}
.pp-token-row h5{
  font-size:10.5px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;
  color:var(--t-muted);margin:0 0 8px;
}
.pp-color-row{display:flex;flex-direction:column;gap:4px}
.pp-color{
  display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:var(--r-sm);
  background:var(--surface-sunken);font-size:11px;font-family:var(--font-mono);
  border:1px solid var(--line-soft);
}
.pp-color .sw{width:18px;height:18px;border-radius:var(--r-sm);border:1px solid rgba(255,255,255,.1);flex-shrink:0}
.pp-color code{color:var(--t-strong);font-weight:600;flex:1}
.pp-color .v{color:var(--t-muted)}
.pp-shadow{
  background:var(--surface-elevated);border-radius:var(--r-md);padding:14px;
  font-size:11px;font-family:var(--font-mono);color:var(--t-muted);text-align:center;
  margin-bottom:6px;border:1px solid var(--line-soft);
}
.pp-radius{width:48px;height:48px;background:var(--c-primary);margin:0 auto 4px}
.pp-spacing-bar{background:var(--c-primary);height:18px;margin-bottom:4px}

/* ============================== MISC ==================================== */
.pp-side-toolbar{display:flex;gap:6px;margin-bottom:var(--sp-3)}
.pp-side-toolbar .mg-btn{flex:1;justify-content:center}

.pp-revs{margin:0;padding:0;list-style:none}
.pp-revs li{padding:9px 0;border-top:1px solid var(--line-soft);font-size:12px;display:flex;justify-content:space-between;gap:10px}
.pp-revs li:first-child{border-top:none;padding-top:4px}
.pp-revs .who{font-weight:700;color:var(--t-strong)}
.pp-revs .when{color:var(--t-muted);font-size:10.5px}
.pp-revs .act{color:var(--c-primary-l);font-size:11px;font-weight:700;text-decoration:none}
.pp-revs .act:hover{text-decoration:underline}

.mg-confirm-input{
  margin-top:var(--sp-3);padding:var(--sp-3);background:rgba(244,63,94,.1);
  border:1px dashed rgba(244,63,94,.3);border-radius:var(--r-sm);
}
.mg-confirm-input label{font-size:11.5px;font-weight:600;color:#fda4af;display:block;margin-bottom:6px}
.mg-confirm-input input{font-family:var(--font-mono);font-weight:600;background:var(--c-950) !important;border-color:rgba(244,63,94,.4) !important}

/* Visually-hidden helper for accessible labels (Issue 7 fix). */
.mg-vh{position:absolute !important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ============================== RESPONSIVE ============================== */
/* Issue 4 fix — graceful collapse on narrow viewports. */
@media (max-width:1024px){
  .mg-edit-grid{grid-template-columns:1fr;gap:var(--sp-4)}
  .mg-edit-side{position:static;top:auto}
  .mg-vtabs{grid-template-columns:1fr}
  .mg-vtabs-nav{
    display:flex;overflow-x:auto;border-right:none;border-bottom:1px solid var(--line);
    padding:8px;gap:4px;
  }
  .mg-vtabs-nav button{flex-shrink:0;width:auto;min-width:140px}
  .pp-tokens-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:768px){
  .mg-wrap{padding:0 var(--sp-4) var(--sp-7)}
  .pp-cover{padding:var(--sp-5) var(--sp-4)}
  .pp-cover h1{font-size:24px}
  .mg-fld-row,.mg-fld-row.three,.mg-fld-row.lr{grid-template-columns:1fr}
  .mg-page-head-row{flex-direction:column;align-items:stretch}
  .mg-page-head-actions{flex-wrap:wrap}
  .mg-summary dl{grid-template-columns:1fr;gap:var(--sp-2) 0}
  .mg-summary dt{margin-top:var(--sp-2)}
  .mg-wizard{padding:var(--sp-3);overflow-x:auto;flex-wrap:nowrap}
  .mg-wizard-step{min-width:120px;flex:0 0 auto}
  .mg-bulk{flex-wrap:wrap}
  .mg-search{display:none}
  .mg-pill span:not(.av):not(.arr){display:none}
  .pp-tokens-grid{grid-template-columns:1fr}
  .mg-modal{width:calc(100vw - 2 * var(--sp-4))}
  .mg-sticky-actions-inner{flex-direction:column;align-items:stretch}
  .mg-sticky-actions-inner .right{justify-content:stretch}
  .mg-sticky-actions-inner .right .mg-btn{flex:1}
}
@media (max-width:480px){
  .mg-page-head h1{font-size:20px}
  .pp-cover h1{font-size:22px}
  .pp-section .ttl{font-size:16px}
  .mg-title-row .title-input{font-size:20px}
  .mg-paragraph-add{flex-direction:column}
  .mg-paragraph-add .add-btn{width:100%}
}

/* ============================== ANNOUNCE STRIP ========================== */
.mg-announce{
  background:linear-gradient(90deg,#1f2937 0%,#111827 100%);
  border-bottom:1px solid #374151;color:#fde68a;
  padding:8px 24px;font-size:12.5px;font-weight:500;
  position:sticky;top:0;z-index:1100;
}
.mg-announce__inner{
  display:flex;align-items:center;gap:14px;width:100%;max-width:1440px;margin:0 auto;
}
.mg-announce__dot{
  width:9px;height:9px;border-radius:50%;background:#fbbf24;
  box-shadow:0 0 0 3px rgba(251,191,36,.25);flex-shrink:0;
}
.mg-announce__msg{flex:1;line-height:1.4;color:#e5e7eb}
.mg-announce__msg strong{color:#fff;font-weight:700}
.mg-announce__cta{
  color:#7dd3fc;font-weight:700;text-decoration:underline;text-underline-offset:2px;
  white-space:nowrap;
}
.mg-announce__cta:hover{color:#bae6fd}
.mg-announce__actions{display:flex;align-items:center;gap:8px;flex-shrink:0}
.mg-announce__search{
  width:32px;height:32px;border-radius:var(--r-sm);background:transparent;border:none;
  color:#cbd5e1;cursor:pointer;font-size:14px;
  display:inline-flex;align-items:center;justify-content:center;transition:var(--t-fast);
}
.mg-announce__search:hover{background:rgba(255,255,255,.08);color:#fff}
.mg-announce__btn{
  display:inline-flex;align-items:center;gap:8px;padding:5px 12px 5px 5px;
  border:1px solid var(--c-primary);background:rgba(34,211,238,.08);color:#67e8f9;
  border-radius:var(--r-pill);font-weight:700;font-size:12.5px;cursor:pointer;
  font-family:var(--font);text-decoration:none;transition:var(--t-fast);
}
.mg-announce__btn .av{
  width:22px;height:22px;border-radius:50%;
  background:linear-gradient(135deg,var(--c-primary),var(--c-primary-l));
  color:var(--c-950);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:10px;font-weight:800;
}
.mg-announce__btn:hover{background:rgba(34,211,238,.16);color:#a5f3fc}
.mg-announce__btn .arr{font-size:9px;opacity:.7}

/* ============================== MEGA MENU =============================== */
.mg-megamenu{
  background:#0f172a;color:#cbd5e1;
  border:1px solid #1e293b;border-radius:12px;
  box-shadow:0 24px 48px rgba(0,0,0,.45);
  position:fixed;top:calc(var(--topbar-h) + 8px);left:12px;right:12px;
  margin-left:auto;margin-right:auto;max-width:1320px;z-index:1099;overflow:hidden;
}
.mg-megamenu__inner{
  display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:0;
  padding:24px 18px 18px;
}
.mg-mm-col{padding:0 10px;border-left:1px solid rgba(255,255,255,.05)}
.mg-mm-col:first-child{border-left:none}
.mg-mm-col .mg-mm-h ~ .mg-mm-h{margin-top:22px}
.mg-mm-h{
  font-size:10.5px;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;
  color:#67e8f9;margin:0 0 12px;padding:0 8px;
}
.mg-mm-link{
  display:flex;align-items:center;gap:11px;padding:8px;border-radius:var(--r-sm);
  color:#e2e8f0;text-decoration:none;font-size:13.5px;font-weight:500;line-height:1.3;
  transition:var(--t-fast);
}
.mg-mm-link:hover{background:rgba(255,255,255,.06);color:#fff}
.mg-mm-link:focus-visible{outline:2px solid var(--c-primary);outline-offset:1px}
.mg-mm-link .ic{
  width:24px;height:24px;border-radius:var(--r-sm);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:13px;flex-shrink:0;line-height:1;
}
.mg-mm-link .ic.c1{background:rgba(244,114,182,.16);color:#fbcfe8}
.mg-mm-link .ic.c2{background:rgba(34,211,238,.16);color:#67e8f9}
.mg-mm-link .ic.c3{background:rgba(168,85,247,.16);color:#d8b4fe}
.mg-mm-link .ic.c4{background:rgba(251,191,36,.16);color:#fde68a}
.mg-mm-link .ic.c5{background:rgba(16,185,129,.16);color:#6ee7b7}
.mg-mm-link .ic.c6{background:rgba(148,163,184,.16);color:#cbd5e1}
.mg-megamenu__foot{
  background:#1e293b;border-top:1px solid #334155;
  padding:14px 24px;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
}
.mg-megamenu__user{display:flex;align-items:center;gap:11px}
.mg-megamenu__user .av{
  width:34px;height:34px;border-radius:50%;
  background:linear-gradient(135deg,var(--c-primary),var(--c-primary-l));
  color:var(--c-950);display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:12px;
}
.mg-megamenu__user .meta{display:flex;align-items:baseline;gap:8px}
.mg-megamenu__user strong{color:#fff;font-weight:700;font-size:13px}
.mg-megamenu__user .role{color:#94a3b8;font-size:12px;font-weight:500}
.mg-megamenu__signout{
  display:inline-flex;align-items:center;gap:6px;padding:7px 14px;
  background:#dc2626;color:#fff;border:1px solid #ef4444;border-radius:var(--r-sm);
  font-weight:700;font-size:12.5px;cursor:pointer;font-family:var(--font);
  text-decoration:none;transition:var(--t-fast);
}
.mg-megamenu__signout:hover{background:#b91c1c;border-color:#dc2626}
.mg-megamenu__signout .ic{font-size:14px;line-height:1}

@media (max-width:1280px){
  .mg-megamenu__inner{grid-template-columns:repeat(3,minmax(0,1fr));row-gap:24px}
}
@media (max-width:768px){
  .mg-announce__inner{flex-wrap:wrap}
  .mg-announce__msg{order:3;flex-basis:100%}
  .mg-megamenu__inner{grid-template-columns:repeat(2,minmax(0,1fr));row-gap:24px;padding:18px 12px}
  .mg-mm-col{padding:0 4px}
}

/* Pill open state */
.mg-topbar .mg-pill[aria-expanded=true]{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.28)}
.mg-topbar .mg-pill[aria-expanded=true] .arr{transform:rotate(180deg)}
.mg-topbar .mg-pill .arr{transition:transform .15s ease}

/* Megamenu opens as a card overlay attached to the topbar */
.mg-megamenu{
  opacity:0;transform:translateY(-6px);
  transition:opacity .14s ease, transform .14s ease;
  pointer-events:none;
}
.mg-megamenu.is-open{opacity:1;transform:translateY(0);pointer-events:auto}
.mg-megamenu[hidden]{display:none}
