:root{
  --bg:#edf2f8;
  --bg-accent:#e3ebf6;
  --surface:#ffffff;
  --surface-muted:#f6f9fc;
  --surface-soft:#eef3f9;
  --border:#d9e3f0;
  --border-strong:#c5d2e3;
  --text:#162131;
  --text-soft:#5d6c81;
  --text-faint:#93a3b8;
  --navy:#12395f;
  --navy-strong:#0b2843;
  --navy-soft:#1e4f7b;
  --green:#7ab236;
  --green-strong:#5f9e1a;
  --red:#d45757;
  --red-soft:#f8e7e7;
  --amber:#d89021;
  --amber-soft:#fff5e5;
  --violet:#715de8;
  --violet-soft:#efeafe;
  --shadow-xs:0 1px 2px rgba(15,23,42,.04);
  --shadow-sm:0 8px 24px rgba(16,24,40,.06);
  --shadow-md:0 18px 50px rgba(15,23,42,.08);
  --radius-sm:10px;
  --radius-md:16px;
  --radius-lg:22px;
  --radius-xl:28px;
  --s:var(--surface);
  --s2:var(--surface-soft);
  --bd:var(--border);
  --r:var(--radius-md);
  --t2:var(--text-soft);
  --t3:var(--text-faint);
  --ac:var(--green);
  --ac2:var(--navy-soft);
}

*{box-sizing:border-box;margin:0;padding:0;}

html{
  scroll-behavior:smooth;
  background:
    radial-gradient(circle at top left, rgba(122,178,54,.08), transparent 24%),
    radial-gradient(circle at top right, rgba(18,57,95,.12), transparent 22%),
    linear-gradient(180deg, #f7fafe 0%, var(--bg) 100%);
}

body{
  min-height:100vh;
  font-family:'Inter','Segoe UI',sans-serif;
  color:var(--text);
  background:transparent;
}

body.auth-locked .topbar,
body.auth-locked .nav-shell,
body.auth-locked .content{
  display:none;
}

body.auth-ready .auth-gate{
  display:none;
}

button,input,select,textarea{font:inherit;}

img{display:block;max-width:100%;}

.app-shell{
  min-height:100vh;
}

.auth-gate{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:32px 18px;
}

.auth-card{
  width:100%;
  max-width:520px;
  min-height:460px;
  position:relative;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:36px 32px;
  border-radius:28px;
  border:1px solid rgba(18,57,95,.08);
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(246,250,253,.96));
  box-shadow:0 30px 80px rgba(9,30,52,.14);
}

.auth-logo{
  position:absolute;
  top:42%;
  left:50%;
  width:clamp(260px, 65%, 340px);
  max-width:70%;
  height:auto;
  margin:0;
  transform:translate(-50%, -58%);
  opacity:.08;
  object-fit:contain;
  pointer-events:none;
  user-select:none;
  z-index:0;
}

.auth-card-content{
  position:relative;
  z-index:1;
  width:100%;
  max-width:360px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:14px;
}

.auth-kicker{
  color:var(--navy-soft);
  font-size:12px;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.auth-card h1{
  font-size:30px;
  line-height:1.05;
  font-weight:800;
  letter-spacing:-.04em;
  color:var(--text);
}

.auth-card p{
  max-width:360px;
  color:var(--text-soft);
  font-size:14px;
  line-height:1.55;
}

.auth-login-btn{
  min-width:260px;
  margin-top:10px;
}

.topbar{
  position:sticky;
  top:0;
  z-index:120;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:16px 24px;
  background:linear-gradient(135deg, rgba(11,40,67,.98), rgba(18,57,95,.96) 54%, rgba(30,79,123,.94));
  border-bottom:1px solid rgba(255,255,255,.1);
  box-shadow:0 16px 44px rgba(9,30,52,.24);
  backdrop-filter:blur(18px);
}

.brand{
  display:flex;
  align-items:center;
  gap:16px;
  min-width:0;
}

.brand-mark{
  display:flex;
  align-items:center;
  justify-content:center;
  width:56px;
  height:56px;
  border-radius:16px;
  background:transparent;
  flex-shrink:0;
}

.brand-mark img{
  width:56px;
  height:56px;
  object-fit:contain;
}

.brand-copy{
  display:flex;
  flex-direction:column;
  gap:5px;
  min-width:0;
}

.brand-row{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
}

.brand-logo{
  height:32px;
  width:auto;
  object-fit:contain;
}

.brand-copy h1{
  font-size:24px;
  line-height:1.05;
  font-weight:800;
  letter-spacing:-.04em;
  color:#fff;
}

.brand-copy p{
  color:rgba(230,239,249,.75);
  font-size:13px;
  line-height:1.4;
  max-width:640px;
}

.topbar-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
  flex-wrap:wrap;
}

.status-cluster{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  margin-right:4px;
}

.status-chip,
.user-chip{
  display:inline-flex;
  align-items:center;
  gap:10px;
  min-height:42px;
  padding:0 16px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
  color:#f3f7fb;
  font-size:12px;
  font-weight:600;
  letter-spacing:.01em;
}

.status-dot{
  width:10px;
  height:10px;
  border-radius:999px;
  background:#4ade80;
  box-shadow:0 0 0 6px rgba(74,222,128,.14);
  flex-shrink:0;
}

.user-chip{
  color:rgba(243,247,251,.84);
  max-width:240px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

.topbar-btns{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
  flex-wrap:wrap;
}

.nav-shell{
  position:sticky;
  top:94px;
  z-index:110;
  padding:14px 24px 0;
}

.tabs{
  display:flex;
  align-items:center;
  gap:10px;
  width:100%;
  padding:10px;
  overflow-x:auto;
  border:1px solid rgba(18,57,95,.08);
  border-radius:20px;
  background:rgba(255,255,255,.86);
  box-shadow:var(--shadow-sm);
  backdrop-filter:blur(18px);
}

.tab-btn{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:48px;
  padding:0 18px;
  border:none;
  border-radius:14px;
  background:transparent;
  color:var(--text-soft);
  font-size:13px;
  font-weight:600;
  white-space:nowrap;
  letter-spacing:-.01em;
  cursor:pointer;
  transition:background .2s ease,color .2s ease,transform .2s ease,box-shadow .2s ease;
}

.tab-btn::after{
  content:'';
  position:absolute;
  left:16px;
  right:16px;
  bottom:7px;
  height:3px;
  border-radius:999px;
  background:transparent;
  transition:background .2s ease,transform .2s ease;
  transform:scaleX(.35);
}

.tab-btn:hover{
  color:var(--navy);
  background:rgba(18,57,95,.06);
}

.tab-btn.active{
  color:var(--navy-strong);
  background:linear-gradient(180deg, rgba(18,57,95,.1), rgba(18,57,95,.05));
  box-shadow:inset 0 0 0 1px rgba(18,57,95,.08);
}

.tab-btn.active::after{
  background:linear-gradient(90deg, var(--green), var(--navy-soft));
  transform:scaleX(1);
}

.tab-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:22px;
  height:22px;
  border-radius:999px;
  background:rgba(18,57,95,.08);
  font-size:12px;
}

.content{
  padding:28px 24px 40px;
}

.view{display:none;}
.view.active{display:block;}

.dashboard-shell{
  display:flex;
  flex-direction:column;
  gap:20px;
}

.dashboard-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:18px;
}

.dashboard-panels{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:42px;
  padding:0 16px;
  border-radius:12px;
  border:1px solid var(--border);
  background:var(--surface);
  color:var(--text-soft);
  font-size:12px;
  font-weight:700;
  letter-spacing:.02em;
  cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease, color .18s ease;
  box-shadow:var(--shadow-xs);
}

.btn:hover{
  transform:translateY(-1px);
  color:var(--navy);
  border-color:rgba(18,57,95,.22);
  box-shadow:var(--shadow-sm);
}

.btn:active{transform:translateY(0);}

.btn-primary{
  color:#fff;
  border-color:transparent;
  background:linear-gradient(135deg, var(--green), #6ca92a);
  box-shadow:0 10px 24px rgba(122,178,54,.22);
}

.btn-primary:hover{
  color:#fff;
  background:linear-gradient(135deg, #84bd40, #6aa11e);
  border-color:transparent;
}

.btn-danger{
  color:var(--red);
  border-color:#f0cccc;
  background:var(--red-soft);
}

.btn-danger:hover{
  color:#b53131;
  border-color:#e7b3b3;
  background:#fae0e0;
}

.btn-amber{
  color:var(--amber);
  border-color:#f3ddaf;
  background:var(--amber-soft);
}

.btn-sm{
  min-height:34px;
  padding:0 13px;
  font-size:11px;
}

.btn-light{
  background:rgba(255,255,255,.1);
  color:#fff;
  border-color:rgba(255,255,255,.18);
  box-shadow:none;
}

.btn-light:hover{
  color:#fff;
  border-color:rgba(255,255,255,.28);
  background:rgba(255,255,255,.16);
  box-shadow:none;
}

.btn-hero{
  min-height:46px;
  padding:0 18px;
}

.kpi-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:18px;
}

.kpi{
  position:relative;
  overflow:hidden;
  padding:22px 22px 20px;
  border-radius:22px;
  border:1px solid rgba(18,57,95,.08);
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(247,250,253,.96));
  box-shadow:var(--shadow-sm);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.kpi:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow-md);
}

.kpi::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:5px;
  background:var(--navy-soft);
}

.kpi::after{
  content:'';
  position:absolute;
  width:120px;
  height:120px;
  right:-36px;
  top:-46px;
  border-radius:999px;
  background:rgba(18,57,95,.06);
}

.kpi-label{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:16px;
  color:var(--text-soft);
  font-size:12px;
  font-weight:700;
  letter-spacing:.01em;
}

.kpi-label::after{
  content:'';
  width:42px;
  height:42px;
  border-radius:16px;
  background:rgba(18,57,95,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
}

.kpi-val{
  position:relative;
  z-index:1;
  font-size:42px;
  line-height:1;
  font-weight:800;
  letter-spacing:-.05em;
}

.kpi-sub{
  position:relative;
  z-index:1;
  margin-top:10px;
  color:var(--text-soft);
  font-size:13px;
}

.kpi.blue::before{background:var(--navy-soft);}
.kpi.green::before{background:var(--green);}
.kpi.red::before{background:var(--red);}
.kpi.amber::before,
.kpi.violet::before{background:var(--violet);}

.kpi.blue .kpi-label::after{background:rgba(18,57,95,.08);}
.kpi.green .kpi-label::after{background:rgba(122,178,54,.12);}
.kpi.red .kpi-label::after{background:rgba(212,87,87,.12);}
.kpi.amber .kpi-label::after,
.kpi.violet .kpi-label::after{background:rgba(113,93,232,.12);}

.sec{
  background:rgba(255,255,255,.94);
  border:1px solid rgba(18,57,95,.08);
  border-radius:24px;
  box-shadow:var(--shadow-sm);
  overflow:hidden;
}

.sec-hdr{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
  padding:18px 22px;
  border-bottom:1px solid rgba(18,57,95,.08);
  background:linear-gradient(180deg, rgba(248,250,253,.95), rgba(244,248,252,.9));
}

.sec-title{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:16px;
  font-weight:700;
  letter-spacing:-.02em;
  color:var(--text);
}

.sec-title::before{
  content:'';
  width:10px;
  height:10px;
  border-radius:999px;
  background:linear-gradient(135deg, var(--green), var(--navy-soft));
  box-shadow:0 0 0 6px rgba(122,178,54,.1);
}

.tbl{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  font-size:13px;
}

.tbl th{
  position:sticky;
  top:0;
  background:var(--surface-soft);
  color:var(--text-soft);
  font-size:11px;
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
  text-align:left;
  padding:14px 18px;
  border-bottom:1px solid var(--border);
}

.tbl td{
  padding:16px 18px;
  vertical-align:middle;
  border-bottom:1px solid rgba(18,57,95,.07);
}

.tbl tbody tr{
  transition:background .18s ease, transform .18s ease;
}

.tbl tbody tr:hover td{
  background:rgba(18,57,95,.03);
}

.tbl tr:last-child td{border-bottom:none;}

.pc{
  margin-bottom:14px;
  border-radius:22px;
  border:1px solid rgba(18,57,95,.08);
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(247,250,253,.98));
  box-shadow:var(--shadow-sm);
  overflow:hidden;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.pc:hover{
  transform:translateY(-2px);
  border-color:rgba(18,57,95,.18);
  box-shadow:var(--shadow-md);
}

.pc-hdr{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  padding:22px 22px 20px;
  cursor:pointer;
  user-select:none;
}

.pc-num{
  font-size:24px;
  line-height:1;
  font-weight:800;
  letter-spacing:-.04em;
  color:var(--navy);
  min-width:120px;
}

.pc-model{
  margin-top:6px;
  font-size:14px;
  font-weight:700;
}

.pc-meta{
  margin-top:6px;
  color:var(--text-soft);
  font-size:12px;
}

.pc-body{
  border-top:1px solid rgba(18,57,95,.08);
  padding:18px 22px 22px;
  background:rgba(243,247,251,.78);
}

.pc-body.hidden{display:none;}

.pipeline{
  display:flex;
  align-items:center;
  gap:4px;
  overflow-x:auto;
  padding-bottom:4px;
}

.ph-step{
  display:flex;
  align-items:center;
  flex-shrink:0;
}

.ph-box{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:4px;
  min-width:98px;
  max-width:98px;
  min-height:92px;
  padding:12px 10px;
  border-radius:18px;
  border:1px solid var(--border);
  background:linear-gradient(180deg, #fff, #f8fbfe);
  box-shadow:var(--shadow-xs);
  cursor:default;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}

.ph-box.click{cursor:pointer;}

.ph-box.click:hover{
  transform:translateY(-2px);
  border-color:rgba(216,144,33,.32);
  background:linear-gradient(180deg, rgba(255,248,235,.95), rgba(255,244,224,.95));
  box-shadow:var(--shadow-sm);
}

.ph-box.done{
  background:linear-gradient(180deg, rgba(122,178,54,.1), rgba(122,178,54,.04));
  border-color:rgba(122,178,54,.22);
}

.ph-box.active{
  background:linear-gradient(180deg, rgba(18,57,95,.12), rgba(18,57,95,.06));
  border-color:rgba(18,57,95,.24);
  box-shadow:0 0 0 4px rgba(18,57,95,.08);
}

.ph-box.blocked{
  background:linear-gradient(180deg, rgba(212,87,87,.12), rgba(212,87,87,.05));
  border-color:rgba(212,87,87,.2);
}

.ph-box.pending{opacity:.48;}
.ph-box.qc{border-style:dashed;}

.ph-ic{
  display:flex;
  align-items:center;
  justify-content:center;
  width:34px;
  height:34px;
  border-radius:12px;
  background:rgba(18,57,95,.08);
  font-size:17px;
}

.ph-nm{
  color:var(--text-soft);
  font-size:10px;
  font-weight:700;
  text-transform:uppercase;
  text-align:center;
  line-height:1.35;
  letter-spacing:.02em;
  word-break:break-word;
}

.ph-st{
  font-size:10px;
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
}

.ph-st.done{color:var(--green-strong);}
.ph-st.active{color:var(--navy-soft);}
.ph-st.blocked{color:var(--red);}

.ph-op{
  max-width:86px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  color:var(--text-faint);
  font-size:10px;
}

.ph-arr{
  padding:0 6px;
  color:var(--text-faint);
  font-size:18px;
  flex-shrink:0;
}

.pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:28px;
  padding:0 11px;
  border-radius:999px;
  font-size:11px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.04em;
  white-space:nowrap;
}

.pg{background:rgba(122,178,54,.12);color:var(--green-strong);border:1px solid rgba(122,178,54,.2);}
.pb{background:rgba(18,57,95,.08);color:var(--navy-soft);border:1px solid rgba(18,57,95,.14);}
.pa{background:rgba(216,144,33,.12);color:var(--amber);border:1px solid rgba(216,144,33,.18);}
.pr{background:rgba(212,87,87,.12);color:var(--red);border:1px solid rgba(212,87,87,.18);}
.pz{background:var(--surface-soft);color:var(--text-soft);border:1px solid var(--border);}

.modal-overlay{
  position:fixed;
  inset:0;
  z-index:200;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:rgba(10,24,42,.48);
  backdrop-filter:blur(10px);
  opacity:0;
  pointer-events:none;
  transition:opacity .22s ease;
}

.modal-overlay.open{
  opacity:1;
  pointer-events:auto;
}

.modal{
  width:100%;
  max-width:620px;
  max-height:90vh;
  overflow-y:auto;
  border-radius:26px;
  border:1px solid rgba(18,57,95,.08);
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(247,250,253,.98));
  box-shadow:0 30px 80px rgba(9,30,52,.24);
  transform:translateY(16px) scale(.985);
  transition:transform .22s ease;
}

.modal-overlay.open .modal{
  transform:translateY(0) scale(1);
}

.mhdr{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:22px 24px 18px;
  border-bottom:1px solid rgba(18,57,95,.08);
}

.mtitle{
  font-size:22px;
  line-height:1.1;
  font-weight:750;
  letter-spacing:-.03em;
  color:var(--text);
}

.mclose{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:38px;
  height:38px;
  border-radius:12px;
  border:1px solid var(--border);
  background:var(--surface-soft);
  color:var(--text-soft);
  cursor:pointer;
  transition:all .18s ease;
}

.mclose:hover{
  color:var(--red);
  border-color:#e7baba;
  background:#fff4f4;
}

.mbody{
  display:flex;
  flex-direction:column;
  gap:16px;
  padding:22px 24px;
}

.mfoot{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
  flex-wrap:wrap;
  padding:18px 24px 22px;
  border-top:1px solid rgba(18,57,95,.08);
}

.fg{
  display:flex;
  flex-direction:column;
  gap:8px;
  min-width:0;
}

.fr{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}

.fl{
  color:var(--text-soft);
  font-size:12px;
  font-weight:700;
  letter-spacing:.01em;
}

.fi,.fsel,.fta,.si{
  width:100%;
  border:1px solid var(--border);
  border-radius:14px;
  background:linear-gradient(180deg, #fff, #fbfdff);
  color:var(--text);
  font-size:14px;
  padding:13px 14px;
  transition:border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.fi:focus,.fsel:focus,.fta:focus,.si:focus{
  outline:none;
  border-color:rgba(18,57,95,.28);
  box-shadow:0 0 0 4px rgba(18,57,95,.08);
  background:#fff;
}

.fta{
  min-height:88px;
  resize:vertical;
}

.qc-box{
  padding:16px;
  border-radius:18px;
  border:1px solid #f0ddb2;
  background:linear-gradient(180deg, #fffaf1, #fff6e9);
}

.qc-title{
  margin-bottom:12px;
  color:var(--amber);
  font-size:12px;
  font-weight:700;
  letter-spacing:.01em;
}

.qc-opts{
  display:flex;
  gap:10px;
}

.qc-opt{
  flex:1;
  min-height:46px;
  display:flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--border);
  border-radius:14px;
  background:#fff;
  color:var(--text-soft);
  font-size:13px;
  font-weight:700;
  cursor:pointer;
  transition:all .18s ease;
}

.qc-opt.ok{
  color:var(--green-strong);
  border-color:rgba(122,178,54,.28);
  background:rgba(122,178,54,.08);
}

.pb-bg{
  height:8px;
  border-radius:999px;
  overflow:hidden;
  background:#dfe8f2;
}

.pb-fill{
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg, var(--green), var(--navy-soft));
  transition:width .45s ease;
}

.sw{
  position:relative;
  min-width:240px;
}

.sw svg{
  position:absolute;
  left:14px;
  top:50%;
  width:16px;
  height:16px;
  transform:translateY(-50%);
  color:var(--text-faint);
  opacity:.9;
  pointer-events:none;
}

.si{
  padding-left:42px;
  min-height:44px;
}

.empty{
  padding:42px 24px;
  text-align:center;
  color:var(--text-faint);
  font-size:13px;
  font-weight:600;
}

.utility-bar{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:18px;
}

.table-wrap{
  width:100%;
  overflow-x:auto;
  overflow-y:hidden;
  -webkit-overflow-scrolling:touch;
}

.table-wrap .tbl{
  min-width:720px;
}

::-webkit-scrollbar{width:10px;height:10px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{
  background:linear-gradient(180deg, #c6d4e5, #9fb4cd);
  border-radius:999px;
  border:2px solid transparent;
  background-clip:padding-box;
}

@media (max-width:1400px){
  .dashboard-grid,
  .kpi-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media (max-width:1100px){
  .topbar{
    flex-direction:column;
    align-items:flex-start;
    gap:16px;
  }

  .topbar-actions,
  .topbar-btns{
    width:100%;
    justify-content:flex-start;
  }

  .topbar-actions{
    flex-direction:column;
    align-items:stretch;
  }

  .status-cluster{
    width:100%;
  }

  .nav-shell{
    top:154px;
  }

  .dashboard-panels{
    grid-template-columns:1fr;
  }
}

@media (max-width:860px){
  .content{padding:22px 16px 32px;}
  .nav-shell{padding:12px 16px 0;}
  .topbar{padding:16px;}
  .brand{align-items:flex-start;}
  .brand-copy h1{font-size:20px;}
  .brand-copy p{font-size:12px;}
  .tabs{border-radius:18px;}
  .dashboard-grid,
  .kpi-grid{
    grid-template-columns:1fr;
  }

  .kpi{
    padding:20px 18px 18px;
  }

  .kpi-val{
    font-size:36px;
  }

  .fr{
    grid-template-columns:1fr;
  }
  .pc-hdr{
    flex-direction:column;
    align-items:flex-start;
  }
  .qc-opts{
    flex-direction:column;
  }
}

@media (max-width:640px){
  .status-cluster{
    width:100%;
  }

  .status-chip,
  .user-chip{
    width:100%;
    justify-content:flex-start;
  }

  .topbar-btns{
    width:100%;
  }

  .topbar-btns .btn{
    flex:1 1 calc(50% - 8px);
    min-height:46px;
  }

  .utility-bar{
    flex-direction:column;
    align-items:stretch;
  }

  .sw{min-width:0;width:100%;}
  .modal-overlay{padding:14px;}
  .modal{border-radius:20px;}
  .mhdr,.mbody,.mfoot{padding-left:18px;padding-right:18px;}
  .tbl th,.tbl td{padding:12px 14px;}
  .table-wrap .tbl{
    min-width:680px;
  }
}

@media (pointer:coarse){
  .btn{
    min-height:46px;
  }

  .btn-sm{
    min-height:40px;
  }

  .tab-btn{
    min-height:50px;
    padding:0 20px;
  }

  .mclose{
    width:42px;
    height:42px;
  }

  .fi,.fsel,.fta,.si{
    min-height:46px;
  }

  .qc-opt{
    min-height:50px;
  }
}
