@import url("https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Manrope:wght@400;600;700&display=swap");

:root{
  --bg: var(--pdx-app-bg, var(--pdx-bg));
  --card: var(--pdx-surface);
  --muted: var(--pdx-muted);
  --text: var(--pdx-text);
  --line: var(--pdx-border);
  --btn: var(--pdx-primary);
  --btnText: var(--pdx-primary-contrast);
  --pdx-app-bg: color-mix(in srgb, var(--pdx-primary-deep) 30%, #0b0f1a 70%);
  --pdx-sidebar-bg: linear-gradient(160deg, color-mix(in srgb, var(--pdx-primary-dark) 48%, #0b0f1a 52%) 0%, #0b0f1a 100%);
  --pdx-sidebar-text: #f8fafc;
  --pdx-sidebar-muted: rgba(248,250,252,0.65);
  --pdx-sidebar-border: rgba(248,250,252,0.18);
  --pdx-sidebar-item: rgba(248,250,252,0.1);
  --pdx-sidebar-item-hover: rgba(248,250,252,0.18);
  --radius-lg: 20px;
  --radius-md: 14px;
  --shadow-1: 0 24px 60px rgba(18, 28, 45, 0.12);
  --shadow-2: 0 12px 28px rgba(18, 28, 45, 0.1);
  --shadow-soft: 0 8px 20px rgba(18, 28, 45, 0.08);
}

*{ box-sizing:border-box; }
body{
  margin:0;
  font-family:"Manrope","Space Grotesk",-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:var(--bg);
  color:var(--text);
}
body::before{
  content:"";
  position:fixed;
  inset:-20% -10% auto auto;
  width:80vw;
  height:80vw;
  background:
    radial-gradient(closest-side at 70% 20%, color-mix(in srgb, var(--pdx-primary-dark) 65%, transparent) 0%, rgba(0,0,0,0) 60%),
    radial-gradient(closest-side at 35% 70%, rgba(255,255,255,0.08) 0%, rgba(0,0,0,0) 70%);
  opacity:.8;
  z-index:-2;
}
body::after{
  content:"";
  position:fixed;
  inset:auto auto -30% -15%;
  width:70vw;
  height:70vw;
  background:
    radial-gradient(closest-side at 20% 70%, rgba(255,255,255,0.06) 0%, rgba(0,0,0,0) 70%),
    radial-gradient(closest-side at 70% 20%, color-mix(in srgb, var(--pdx-primary-deep) 65%, transparent) 0%, rgba(0,0,0,0) 55%),
    radial-gradient(closest-side at 10% 20%, color-mix(in srgb, var(--pdx-accent) 55%, transparent) 0%, rgba(0,0,0,0) 50%);
  opacity:.5;
  z-index:-2;
}

.bg-spark{
  position:fixed;
  width:220px;
  height:220px;
  border-radius:50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--pdx-primary) 55%, #ffffff 45%) 0%, rgba(255,255,255,0) 60%);
  mix-blend-mode: screen;
  opacity:.28;
  z-index:-1;
  pointer-events:none;
  animation: sparkFloat 18s ease-in-out infinite;
}
.bg-spark.s1{ top:8%; left:12%; }
.bg-spark.s2{ top:20%; right:18%; animation-delay: -4s; }
.bg-spark.s3{ bottom:12%; left:22%; animation-delay: -8s; }
.bg-spark.s4{ bottom:6%; right:12%; animation-delay: -12s; }

@keyframes sparkFloat{
  0%, 100%{ transform: translateY(0) translateX(0); }
  50%{ transform: translateY(-18px) translateX(12px); }
}

a{ color:inherit; text-decoration:none; }
.muted{ color:var(--muted); }

.app{
  display:grid;
  grid-template-columns: 280px 1fr;
  gap:18px;
  min-height:100vh;
  padding:18px;
}

.sidebar{
  position:sticky;
  top:18px;
  height:calc(100vh - 36px);
  border:1px solid var(--pdx-sidebar-border);
  border-radius:var(--radius-lg);
  padding:18px;
  background: var(--pdx-sidebar-bg);
  box-shadow: 0 30px 60px rgba(0,0,0,0.35);
  color: var(--pdx-sidebar-text);
  display:flex;
  flex-direction:column;
  gap:16px;
  position:relative;
}
.sidebar .sidebar-toggle--inside{
  position:absolute;
  top:12px;
  right:12px;
  width:36px;
  height:36px;
  border-radius:12px;
  border:1px solid var(--pdx-sidebar-border);
  background: rgba(255,255,255,0.1);
  box-shadow: none;
}
.sidebar .sidebar-toggle--inside span{
  background: var(--pdx-sidebar-text);
}
.sidebar .sidebar-toggle--inside:hover{
  background: rgba(255,255,255,0.18);
}

.sidebar-scrim{
  display:none;
}

.sidebar-toggle{
  display:none;
  width:42px;
  height:42px;
  border-radius:12px;
  border:1px solid var(--line);
  background: rgba(255,255,255,0.8);
  box-shadow: var(--shadow-soft);
  align-items:center;
  justify-content:center;
  gap:4px;
  padding:0;
}
.sidebar-toggle span{
  display:block;
  width:18px;
  height:2px;
  background: var(--pdx-text);
  border-radius:999px;
}

.brand{
  display:flex;
  gap:12px;
  align-items:center;
  padding-bottom:14px;
  border-bottom:1px dashed var(--line);
}
.brand-mark{
  width:46px;
  height:46px;
  border-radius:16px;
  background: linear-gradient(140deg, var(--pdx-primary), var(--pdx-primary-dark));
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow: var(--shadow-soft);
}
.brand-dot{
  width:16px;
  height:16px;
  border-radius:50%;
  background: var(--pdx-primary-contrast);
  box-shadow: inset 0 0 0 4px rgba(255,255,255,0.35);
}
.brand-meta{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.brand-name{
  font-family:"Space Grotesk","Manrope",sans-serif;
  font-weight:700;
  font-size:18px;
  letter-spacing:.2px;
}
.brand-sub{
  color:var(--pdx-sidebar-muted);
  font-size:12px;
}
.brand-tag{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:3px 8px;
  border-radius:999px;
  font-size:11px;
  font-weight:600;
  letter-spacing:.3px;
  background: rgba(255,255,255,0.12);
  color: var(--pdx-sidebar-text);
  border:1px solid var(--pdx-sidebar-border);
  max-width:max-content;
}

.nav-group{
  display:flex;
  flex-direction:column;
  gap:10px;
  flex:1;
  overflow-y:auto;
  padding-right:6px;
}
.nav-group::-webkit-scrollbar{
  width:6px;
}
.nav-group::-webkit-scrollbar-thumb{
  background: rgba(255,255,255,0.25);
  border-radius:999px;
}
.nav-group::-webkit-scrollbar-track{
  background: transparent;
}
.nav-label{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:1.6px;
  color:var(--pdx-sidebar-muted);
}
.nav{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.nav-item{
  position:relative;
  padding:12px 14px;
  border-radius:var(--radius-md);
  background: var(--pdx-sidebar-item);
  border:1px solid var(--pdx-sidebar-border);
  font-weight:600;
  color:var(--pdx-sidebar-text);
  display:flex;
  align-items:center;
  gap:10px;
  transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease, background .12s ease;
}
.nav-icon{
  width:20px;
  height:20px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:inherit;
}
.nav-icon svg{
  width:18px;
  height:18px;
}
.nav-text{
  flex:1;
}
.nav-item:hover{
  border-color: var(--pdx-primary);
  background: var(--pdx-sidebar-item-hover);
  transform:translateY(-1px);
  box-shadow: var(--shadow-soft);
}
.nav-item.is-active{
  background: linear-gradient(135deg, var(--pdx-primary), var(--pdx-primary-dark));
  color: var(--pdx-primary-contrast);
  border-color: var(--pdx-primary);
  box-shadow: 0 14px 30px rgba(0,0,0,0.12);
}
.nav-logout{
  background: transparent;
  border:1px dashed var(--pdx-sidebar-border);
}

.sidebar-footer{
  margin-top:auto;
}

.main{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.topbar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:16px 20px;
  border-radius:var(--radius-lg);
  background: linear-gradient(120deg, var(--pdx-surface) 0%, var(--pdx-accent-soft-2) 100%);
  border:1px solid var(--line);
  box-shadow: var(--shadow-soft);
}
.topbar strong{
  font-family:"Space Grotesk","Manrope",sans-serif;
  font-size:18px;
}
.topbar-left, .topbar-right{
  display:flex;
  align-items:center;
  gap:10px;
}

.content{
  padding:18px;
  border-radius:var(--radius-lg);
  background: color-mix(in srgb, var(--pdx-surface-alt) 82%, #ffffff 18%);
  border:1px solid var(--line);
  box-shadow: var(--shadow-2);
}

.card{
  border:1px solid var(--line);
  background: var(--card);
  border-radius:18px;
  padding:16px;
  box-shadow: var(--shadow-soft);
}

.card > h1, .card > h2, .card > h3{
  margin-top:0;
}

.card .section-title{
  font-family:"Space Grotesk","Manrope",sans-serif;
  font-weight:700;
  letter-spacing:.3px;
}

.card details{
  border:1px solid var(--pdx-border);
  border-radius:14px;
  padding:6px 8px;
  background: color-mix(in srgb, var(--pdx-surface-alt) 75%, #ffffff 25%);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.5);
}
.card details + details{
  margin-top:10px;
}
.card details > summary{
  cursor:pointer;
  list-style:none;
  padding:8px 10px;
  border-radius:10px;
  font-weight:600;
  background: var(--pdx-accent-soft-2);
  border:1px solid var(--pdx-border);
}
.card details[open] > summary{
  background: var(--pdx-accent-soft);
}
.card details > summary::-webkit-details-marker{ display:none; }
.card details > summary::after{
  content:"+";
  float:right;
  color:var(--pdx-muted);
  font-weight:700;
}
.card details[open] > summary::after{
  content:"–";
}
.card details > summary + *{
  margin-top:10px;
}

.card hr,
.divider{
  border:0;
  height:1px;
  background: linear-gradient(90deg, transparent, var(--pdx-border), transparent);
  margin:12px 0;
}

.sidebar, .topbar, .content{
  animation: floatIn .55s ease both;
}
.sidebar{ animation-delay: .02s; }
.topbar{ animation-delay: .04s; }
.content{ animation-delay: .06s; }

.card{
  animation: riseIn .45s ease both;
}
.card:nth-of-type(2){ animation-delay: .06s; }
.card:nth-of-type(3){ animation-delay: .12s; }
.card:nth-of-type(4){ animation-delay: .18s; }

@keyframes floatIn{
  from{ opacity:0; transform:translateY(14px); }
  to{ opacity:1; transform:translateY(0); }
}

@keyframes riseIn{
  from{ opacity:0; transform:translateY(10px) scale(.98); }
  to{ opacity:1; transform:translateY(0) scale(1); }
}

.messages{ margin-bottom:12px; display:flex; flex-direction:column; gap:8px; }
.msg{ border:1px solid var(--line); background:rgba(255,255,255,0.6); padding:10px 12px; border-radius:12px; font-size:14px; }
.msg-error{ border-color:#5b1a1a; }
.msg-success{ border-color:#1a5b2a; }

.auth-wrap{ min-height:100vh; display:flex; align-items:center; justify-content:center; padding:18px; }
.auth-card{ width:380px; border:1px solid var(--line); background:var(--card); border-radius:18px; padding:18px; box-shadow: var(--shadow-2); }
.auth-card form{ margin-top:12px; display:flex; flex-direction:column; gap:8px; }
label{ font-size:12px; color:var(--muted); }
.label-required{
  display:inline-flex;
  align-items:center;
  gap:6px;
}
.req-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:2px 6px;
  border-radius:999px;
  font-size:9px;
  letter-spacing:1px;
  text-transform:uppercase;
  color: var(--pdx-primary-contrast);
  background: var(--pdx-primary);
}
.field-hint{
  font-size:11px;
  color: var(--pdx-muted);
  margin-top:4px;
}
.field-error{
  font-size:11px;
  color: var(--pdx-text);
  background: color-mix(in srgb, var(--pdx-danger) 12%, #ffffff 88%);
  border:1px solid color-mix(in srgb, var(--pdx-danger) 30%, #ffffff 70%);
  padding:6px 8px;
  border-radius:10px;
  margin-top:6px;
}
.input-error{
  border-color: var(--pdx-danger) !important;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--pdx-danger) 22%, transparent);
}
input, select, textarea{
  padding:10px 12px;
  border-radius:12px;
  border:1px solid var(--line);
  background: color-mix(in srgb, var(--pdx-surface) 85%, var(--pdx-accent-soft-2) 15%);
  color:var(--text);
  outline:none;
}
input:focus, select:focus, textarea:focus{
  border-color: var(--pdx-primary);
  box-shadow: 0 0 0 3px var(--pdx-accent-soft);
}
button{ margin-top:6px; padding:10px 12px; border-radius:12px; border:1px solid var(--line); background:var(--btn); color:var(--btnText); font-weight:700; cursor:pointer; box-shadow: var(--shadow-soft); }
button:hover{ opacity:.92; }
button:active{ transform:translateY(1px); }
button.secondary{
  background: var(--pdx-surface-alt);
  color: var(--pdx-text);
  border-color: var(--pdx-border);
}

.auth-links{ margin-top:12px; display:flex; gap:10px; justify-content:center; color:var(--muted); font-size:13px; }
.auth-links a:hover{ color:var(--text); }

/* ===== Public Auth Pages ===== */
.public-auth .main{
  min-height:100vh;
  padding:0;
  background: transparent;
}
.public-auth .content{
  padding:0;
  background: transparent;
  border:0;
  box-shadow:none;
}
.public-auth::before{
  content:"";
  position:fixed;
  inset:0;
  background:
    linear-gradient(120deg, rgba(0,0,0,0.2), transparent 40%),
    radial-gradient(circle at 20% 20%, rgba(255,255,255,0.06), transparent 50%),
    radial-gradient(circle at 80% 70%, rgba(255,255,255,0.04), transparent 55%);
  z-index:-3;
  animation: glowShift 22s ease-in-out infinite;
}
.public-auth::after{
  content:"";
  position:fixed;
  inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.05) 1px, transparent 1px);
  background-size: 120px 120px;
  opacity:.35;
  z-index:-2;
  pointer-events:none;
  animation: gridDrift 40s linear infinite;
}
.public-auth .noise{
  position:fixed;
  inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120' viewBox='0 0 120 120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='120' height='120' filter='url(%23n)' opacity='0.15'/%3E%3C/svg%3E");
  mix-blend-mode: soft-light;
  opacity:.3;
  z-index:-1;
  pointer-events:none;
}
.auth-scan{
  position:fixed;
  inset:-40% auto auto -20%;
  width:180%;
  height:240px;
  background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.18) 50%, transparent 100%);
  opacity:.12;
  z-index:-1;
  transform: skewY(-6deg);
  animation: scanSweep 14s linear infinite;
  pointer-events:none;
}
.auth-orbit{
  position:fixed;
  right:-80px;
  top:-80px;
  width:320px;
  height:320px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,0.18);
  box-shadow: 0 0 40px rgba(255,255,255,0.08);
  z-index:-1;
  animation: orbitSpin 28s linear infinite;
  pointer-events:none;
}
.auth-orbit.o2{
  left:-120px;
  right:auto;
  bottom:-120px;
  top:auto;
  width:380px;
  height:380px;
  border-color: rgba(255,255,255,0.12);
  animation-duration: 36s;
  animation-direction: reverse;
}

@keyframes glowShift{
  0%,100%{ transform: translateY(0) translateX(0); opacity:.9; }
  50%{ transform: translateY(12px) translateX(-10px); opacity:.75; }
}

@keyframes gridDrift{
  0%{ background-position: 0 0, 0 0; }
  100%{ background-position: 240px 240px, 240px 240px; }
}

@keyframes scanSweep{
  0%{ transform: translateX(-40%) skewY(-6deg); }
  100%{ transform: translateX(20%) skewY(-6deg); }
}

@keyframes orbitSpin{
  from{ transform: rotate(0deg); }
  to{ transform: rotate(360deg); }
}
.auth-shell{
  min-height:100vh;
  display:grid;
  grid-template-columns: minmax(0,1.1fr) minmax(0,0.9fr);
  gap:32px;
  padding: clamp(24px, 4vw, 64px);
  align-items:stretch;
}
.auth-hero{
  position:relative;
  border-radius:28px;
  padding: clamp(28px, 4vw, 56px);
  color:#f8fafc;
  background: linear-gradient(150deg, var(--pdx-primary-deep), var(--pdx-primary-dark));
  overflow:hidden;
  box-shadow: 0 40px 80px rgba(0,0,0,0.35);
}
.auth-hero::before{
  content:"";
  position:absolute;
  inset:-20% -10% auto auto;
  width:70%;
  height:70%;
  background: radial-gradient(circle, rgba(255,255,255,0.25) 0%, rgba(255,255,255,0) 60%);
  opacity:.7;
}
.auth-hero::after{
  content:"";
  position:absolute;
  inset:auto auto -20% -10%;
  width:60%;
  height:60%;
  background: radial-gradient(circle, rgba(255,255,255,0.2) 0%, rgba(255,255,255,0) 70%);
  opacity:.5;
}
.hero-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 12px;
  border-radius:999px;
  font-size:11px;
  letter-spacing:1px;
  text-transform:uppercase;
  background: rgba(255,255,255,0.16);
  border:1px solid rgba(255,255,255,0.24);
}
.hero-title{
  font-family:"Space Grotesk","Manrope",sans-serif;
  font-size: clamp(40px, 7vw, 96px);
  font-weight:700;
  letter-spacing:1px;
  margin-top:18px;
}
.hero-tagline{
  font-size: clamp(16px, 2.2vw, 22px);
  font-weight:600;
  margin-top:6px;
}
.hero-lead{
  margin-top:14px;
  max-width:560px;
  color: rgba(248,250,252,0.85);
  font-size:15px;
  line-height:1.6;
}
.hero-points{
  margin-top:18px;
  display:grid;
  gap:10px;
}
.hero-points .point{
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-size:14px;
  color: rgba(248,250,252,0.9);
}
.hero-points .dot{
  width:10px;
  height:10px;
  border-radius:50%;
  background: rgba(255,255,255,0.8);
  margin-top:6px;
}
.hero-footer{
  margin-top:18px;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.hero-pill{
  padding:6px 12px;
  border-radius:999px;
  background: rgba(255,255,255,0.12);
  border:1px solid rgba(255,255,255,0.2);
  font-size:11px;
  letter-spacing:1px;
  text-transform:uppercase;
}
.hero-metrics{
  margin-top:18px;
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(140px,1fr));
  gap:10px;
}
.hero-metric{
  padding:12px;
  border-radius:14px;
  background: rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.16);
}
.metric-value{
  font-size:18px;
  font-weight:700;
}
.metric-label{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:1px;
  color: rgba(248,250,252,0.75);
}
.auth-panel{
  display:flex;
  align-items:center;
  justify-content:center;
}
.auth-card{
  width:min(480px, 100%);
  border:1px solid var(--pdx-border);
  border-radius:24px;
  padding:26px;
  background: rgba(255,255,255,0.96);
  box-shadow: 0 28px 60px rgba(0,0,0,0.2);
}
.auth-card h2{
  margin:0 0 6px 0;
  font-size:22px;
}
.auth-sub{
  margin:0 0 18px 0;
  color: var(--pdx-muted);
}
.auth-form{
  display:grid;
  gap:12px;
}
.auth-form.two-col{
  grid-template-columns: repeat(2, minmax(0,1fr));
}
.auth-form .field{
  display:flex;
  flex-direction:column;
  gap:6px;
  position:relative;
}
.auth-form .field.full{
  grid-column: 1 / -1;
}
.auth-form .field.has-icon .field-icon{
  position:absolute;
  left:12px;
  top:34px;
  width:18px;
  height:18px;
  color: var(--pdx-muted);
}
.auth-form .field.has-icon .field-icon svg{
  width:18px;
  height:18px;
}
.auth-form .input-icon{
  padding-left:38px;
}
.auth-actions{
  margin-top:4px;
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.auth-links{
  margin-top:14px;
  display:flex;
  gap:10px;
  justify-content:flex-start;
  color:var(--pdx-muted);
  font-size:13px;
}

@media (max-width: 980px){
  .auth-shell{
    grid-template-columns: 1fr;
  }
  .auth-hero{
    order:1;
  }
  .auth-panel{
    order:2;
  }
}

.chip{
  background: rgba(255,255,255,0.72);
  border:1px solid var(--line);
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  color: var(--muted);
}

.chip-warn{
  border-color:#5b4b1a;
}

.chip-brand{
  background: var(--pdx-accent-soft);
  color: var(--pdx-text);
  border-color: var(--pdx-primary);
  font-weight:600;
}

.chip-logo{
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.chip-logo img{
  width:18px;
  height:18px;
  object-fit:contain;
  border-radius:4px;
  background: #fff;
  padding:2px;
}

.brand-top{
  display:flex;
  align-items:center;
  justify-content:flex-end;
}
.brand-top img{
  height:34px;
  width:auto;
  object-fit:contain;
}
.brand-top-text{
  font-size:18px;
  font-weight:700;
  letter-spacing:.4px;
  color: var(--pdx-primary);
  text-transform:none;
}

.table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
}
.table thead th{
  text-align:left;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:1px;
  color:var(--muted);
  padding:10px 12px;
  border-bottom:1px solid var(--line);
}
.table tbody td{
  padding:10px 12px;
  border-bottom:1px solid var(--line);
  background: color-mix(in srgb, var(--pdx-surface) 85%, #ffffff 15%);
}
.table tbody tr:nth-child(even) td{
  background: color-mix(in srgb, var(--pdx-surface-alt) 80%, #ffffff 20%);
}
.table tbody tr:hover td{
  background: var(--pdx-accent-soft);
}
.table tbody tr:last-child td{
  border-bottom:0;
}
.table td a{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  background: var(--pdx-accent-soft-2);
  border:1px solid var(--pdx-border);
  color: var(--pdx-text);
  margin-right:6px;
}
.table td a:hover{
  background: var(--pdx-accent-soft);
  border-color: var(--pdx-primary);
}

@media (max-width: 980px){
  .app{
    grid-template-columns: 1fr;
    padding:14px;
  }
  .main{
    min-height:100vh;
  }
  .sidebar{
    position:fixed;
    left:16px;
    top:16px;
    height:calc(100vh - 32px);
    width:min(86vw, 320px);
    transform:translateX(-120%);
    transition:transform .2s ease;
    z-index:50;
  }
  .sidebar .sidebar-toggle--inside{
    display:inline-flex;
  }
  .brand{
    padding-right:40px;
  }
  body.sidebar-open .sidebar{
    transform:translateX(0);
  }
  .sidebar-scrim{
    display:block;
    position:fixed;
    inset:0;
    background:rgba(10,12,16,0.4);
    opacity:0;
    pointer-events:none;
    transition:opacity .2s ease;
    z-index:40;
  }
  body.sidebar-open .sidebar-scrim{
    opacity:1;
    pointer-events:auto;
  }
  body.sidebar-open{
    overflow:hidden;
  }
  .nav{
    flex-direction:row;
    flex-wrap:wrap;
  }
  .nav-item{
    flex:1 1 160px;
  }
  .content{
    min-height:calc(100vh - 120px);
  }
  body.sidebar-open .main,
  body.sidebar-open .content,
  body.sidebar-open .topbar{
    visibility:hidden;
  }
  .sidebar-toggle{
    display:inline-flex;
  }
}

@media (prefers-reduced-motion: reduce){
  .sidebar, .topbar, .content, .card{
    animation: none;
  }
  .bg-spark{
    animation: none;
  }
  .public-auth::before,
  .public-auth::after,
  .auth-scan,
  .auth-orbit{
    animation: none;
  }
}

/* ===== Modal (dialog) ===== */
.modal::backdrop {
  background: rgba(0,0,0,.45);
}

.modal {
  border: 0;
  padding: 0;
  background: transparent;
}

/* dialog default min-width/padding vs. override */
dialog.modal[open]{
  padding:0;
}

.modal-card {
  width: min(980px, calc(100vw - 24px));
  max-height: min(82vh, 820px);
  margin: 8vh auto;
  background: var(--pdx-surface);
  border: 1px solid var(--pdx-border);
  border-radius: 16px;
  box-shadow: 0 14px 40px rgba(0,0,0,.18);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.modal-head, .modal-foot {
  padding: 12px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px solid var(--pdx-border);
}

.modal-foot {
  border-top: 1px solid var(--pdx-border);
  border-bottom: 0;
}

.modal-title {
  font-weight: 700;
  font-size: 16px;
}

.modal-body {
  padding: 12px 14px;
  overflow: auto;
}

.prebox {
  white-space: pre;
  margin: 0;
  padding: 12px;
  border-radius: 12px;
  background: rgba(255,255,255,0.7);
  border: 1px solid var(--pdx-border);
  font-size: 12.5px;
  line-height: 1.35;
}

/* ghost buton */
.btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}

.btn.btn-ghost {
  background: transparent;
  border: 1px solid var(--pdx-border);
  color: var(--pdx-text);
}

.btn.btn-ghost:hover {
  background: rgba(17,24,39,0.04);
}
