:root{
  --bg:#f3f6fb;
  --card:#fff;
  --text:#0f172a;
  --muted:#64748b;
  --line:#e2e8f0;
  --blue:#0f62fe;
  --green:#16a34a;
  --orange:#f59e0b;
  --purple:#6d5dfc;
  --nav:#071628;
  --shadow:0 10px 28px rgba(15,23,42,.07);
  --radius:12px;
}

*{box-sizing:border-box}

body{
  margin:0;
  font-family:Inter,Segoe UI,Roboto,Arial,sans-serif;
  background:var(--bg);
  color:var(--text);
}

body.locked{
  overflow:hidden;
}

body.quote-modal-open{
  overflow:hidden;
}

[hidden]{
  display:none!important;
}

button,input,select,textarea{font-family:inherit}

select{
  appearance:none;
  -webkit-appearance:none;
  min-width:0;
  padding-right:36px!important;
  background-image:linear-gradient(45deg,transparent 50%,#334155 50%),linear-gradient(135deg,#334155 50%,transparent 50%);
  background-position:calc(100% - 18px) 50%,calc(100% - 13px) 50%;
  background-size:5px 5px,5px 5px;
  background-repeat:no-repeat;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

.app{
  min-height:100vh;
  display:grid;
  grid-template-columns:260px 1fr;
  transition:grid-template-columns .22s ease;
}

.sidebar{
  background:linear-gradient(180deg,#061222,#0b1f38);
  color:#fff;
  padding:24px 18px;
  height:100vh;
  position:sticky;
  top:0;
  display:flex;
  flex-direction:column;
  transition:width .22s ease,padding .22s ease,transform .22s ease;
}

.brand{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  padding-bottom:20px;
  border-bottom:1px solid rgba(255,255,255,.13);
}

.brand-icon{
  width:44px;
  height:44px;
  border:1px solid rgba(255,255,255,.86);
  border-radius:8px;
  display:grid;
  place-items:center;
  overflow:hidden;
  background:#fff;
}

.sidebar .brand-icon{
  width:132px;
  height:74px;
}

.brand-icon img{
  width:100%;
  height:100%;
  object-fit:contain;
  padding:6px;
}

.brand h1{
  font-size:17px;
  line-height:1.25;
  margin:0;
}

.brand.has-logo .brand-title{
  display:none;
}

.brand.no-logo{
  justify-content:flex-start;
}

.brand.no-logo .brand-icon{
  display:none;
}

.menu{
  margin-top:24px;
  display:flex;
  flex-direction:column;
  gap:8px;
}

.menu-item{
  border:0;
  background:transparent;
  color:#dbeafe;
  display:flex;
  align-items:center;
  gap:12px;
  width:100%;
  padding:14px;
  border-radius:8px;
  font-weight:800;
  cursor:pointer;
  text-align:left;
}

.menu-item:hover,.menu-item.active{
  background:var(--blue);
  color:white;
  box-shadow:0 10px 22px rgba(15,98,254,.25);
}

.sidebar-footer{
  margin-top:auto;
  border-top:1px solid rgba(255,255,255,.13);
  padding-top:16px;
  color:#cbd5e1;
  display:grid;
  gap:6px;
}

.sidebar-footer strong{
  color:#fff;
  font-size:13px;
  line-height:1.25;
}

.sidebar-footer small{
  font-size:12px;
  line-height:1.25;
}

.topbar{
  height:74px;
  background:#fff;
  border-bottom:1px solid var(--line);
  display:flex;
  align-items:center;
  gap:18px;
  padding:0 28px;
  position:sticky;
  top:0;
  z-index:10;
}

.hamb{
  border:0;
  background:transparent;
  font-size:22px;
  cursor:pointer;
}

.topbar h1{
  font-size:24px;
  margin:0;
  white-space:nowrap;
}

.search{
  flex:1;
  position:relative;
  max-width:620px;
  margin-left:auto;
}

.search span{
  position:absolute;
  left:14px;
  top:50%;
  transform:translateY(-50%);
}

.search input{
  width:100%;
  height:44px;
  border:1px solid var(--line);
  background:#f8fafc;
  border-radius:8px;
  padding:0 82px 0 42px;
  outline:none;
  font-weight:700;
  color:#334155;
}

.search kbd{
  position:absolute;
  right:12px;
  top:50%;
  transform:translateY(-50%);
  background:#e2e8f0;
  color:#64748b;
  border-radius:6px;
  padding:4px 8px;
  font-size:12px;
}

.user-actions{
  display:flex;
  align-items:center;
  gap:12px;
  white-space:nowrap;
}

.round{
  width:36px;
  height:36px;
  border:0;
  border-radius:50%;
  background:#f8fafc;
  position:relative;
}

.bubble{
  position:absolute;
  top:-4px;
  right:-3px;
  width:18px;
  height:18px;
  border-radius:50%;
  background:#ef4444;
  color:#fff;
  font-size:11px;
  display:grid;
  place-items:center;
}

.avatar{
  width:42px;
  height:42px;
  border-radius:50%;
  background:var(--blue);
  color:#fff;
  font-weight:900;
  display:grid;
  place-items:center;
}

.compact-btn{
  min-height:34px;
  padding:0 12px;
}

.user-name{
  font-weight:900;
}

.user-name small{
  display:block;
  color:#64748b;
  font-weight:700;
}

.content{
  padding:24px 28px 32px;
  display:grid;
  grid-template-columns:minmax(0,1fr) 330px;
  gap:20px;
}

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

.stat-card,.panel{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}

.stat-card{
  padding:22px;
  display:flex;
  gap:16px;
  align-items:center;
  min-height:112px;
}

.stat-icon{
  width:58px;
  height:58px;
  color:white;
  border-radius:10px;
  display:grid;
  place-items:center;
  font-size:27px;
}

.blue{background:#0f62fe}
.green{background:#16a34a}
.purple{background:#6d5dfc}
.orange{background:#f59e0b}

.stat-card p{
  margin:0 0 6px;
  color:#334155;
  font-weight:800;
}

.stat-card strong{
  display:block;
  font-size:27px;
  margin-bottom:4px;
}

.up{
  color:#16a34a;
  font-weight:900;
  font-size:13px;
}

.main-col,.side-col{
  display:flex;
  flex-direction:column;
  gap:18px;
  min-width:0;
}

.upload-zone{
  min-height:222px;
  border:2px dashed #3b82f6;
  background:#fff;
  border-radius:12px;
  display:grid;
  grid-template-columns:185px 1fr 310px;
  align-items:center;
  gap:22px;
  padding:24px;
  box-shadow:var(--shadow);
}

.upload-zone.drag{
  background:#eff6ff;
  border-color:#0f62fe;
}

.pdf-icon{
  margin:auto;
  width:92px;
  height:118px;
  border-radius:10px;
  background:linear-gradient(180deg,#eef4fb,#dfe8f4);
  position:relative;
  display:grid;
  place-items:center;
  font-weight:900;
}

.pdf-icon:before{
  content:"";
  position:absolute;
  top:0;
  right:0;
  border-top:28px solid #fff;
  border-left:28px solid #cbd5e1;
}

.pdf-icon span{
  background:#0f62fe;
  color:#fff;
  border-radius:6px;
  padding:7px 10px;
  z-index:1;
}

.upload-text{
  text-align:center;
}

.upload-text h2{
  margin:0 0 10px;
  font-size:22px;
}

.upload-text p{
  color:#64748b;
  font-weight:700;
  margin:7px 0;
}

.upload-text small{
  display:block;
  color:#64748b;
  margin-top:12px;
  font-weight:700;
}

.ocr-box{
  background:linear-gradient(180deg,#eff6ff,#f8fbff);
  border:1px solid #dbeafe;
  border-radius:10px;
  padding:20px;
}

.ocr-box h3{
  margin:0 0 9px;
  color:#0f62fe;
}

.ocr-box p{
  margin:0 0 14px;
  color:#64748b;
  font-weight:700;
  line-height:1.45;
}

.ocr-box span{
  display:inline-flex;
  background:#dcfce7;
  color:#15803d;
  border-radius:999px;
  padding:7px 10px;
  font-weight:900;
  font-size:12px;
}

.btn{
  border:0;
  min-height:40px;
  padding:0 16px;
  border-radius:8px;
  font-weight:900;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  text-decoration:none;
  transition:.2s;
}

.btn:hover{transform:translateY(-1px)}
.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}

.btn.primary{
  background:var(--blue);
  color:#fff;
  box-shadow:0 10px 20px rgba(15,98,254,.24);
}

.btn.ghost{
  background:#fff;
  color:#334155;
  border:1px solid var(--line);
}

.btn.danger{color:#dc2626}

.btn.full{
  width:100%;
  margin-top:9px;
}

.panel{
  overflow:hidden;
}

.panel-head{
  padding:18px 20px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  border-bottom:1px solid var(--line);
}

.panel-head h2{
  display:flex;
  align-items:center;
  gap:10px;
  margin:0;
  font-size:18px;
}

.panel-head h2 span{
  background:#dbeafe;
  color:#0f62fe;
  border-radius:999px;
  padding:5px 10px;
  font-size:12px;
}

.panel-actions{
  display:flex;
  flex-wrap:wrap;
  gap:9px;
  justify-content:flex-end;
}

.panel-actions .compact-select{
  width:auto;
  min-width:190px;
  height:38px;
  margin-top:0;
}

.table-wrap{
  overflow-x:auto;
}

table{
  width:100%;
  border-collapse:collapse;
}

th{
  background:#f8fafc;
  color:#1e293b;
  text-align:left;
  font-size:13px;
  padding:13px 15px;
  border-bottom:1px solid var(--line);
  white-space:nowrap;
}

td{
  color:#334155;
  font-weight:700;
  padding:13px 15px;
  border-bottom:1px solid #edf2f7;
  vertical-align:middle;
}

tbody tr:hover td{background:#f8fbff}

.empty-state{
  text-align:center;
  color:#64748b;
  padding:30px 15px;
  font-weight:800;
  background:linear-gradient(180deg,#fff,#fbfdff);
}

.pill{
  display:inline-flex;
  align-items:center;
  padding:5px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
}

.pill.stock,.pill.ok{
  background:#dcfce7;
  color:#15803d;
}

.pill.buy{
  background:#ffedd5;
  color:#ea580c;
}

.pill.alert{
  background:#fef3c7;
  color:#b45309;
}

.pill.pending{
  background:#e2e8f0;
  color:#475569;
}

.row-actions{
  display:flex;
  gap:6px;
}

.icon-action{
  width:32px;
  height:32px;
  border-radius:8px;
  border:1px solid var(--line);
  background:#fff;
  cursor:pointer;
}

.icon-action:empty{
  display:none;
}

.total-bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:18px 20px;
}

.total-bar strong{
  color:#0f62fe;
  font-size:18px;
}

.manual{
  padding:20px;
}

.manual h2{
  margin:0 0 18px;
  font-size:18px;
}

.manual h2 small{
  color:#64748b;
  font-size:13px;
}

.manual-grid{
  display:grid;
  grid-template-columns:2fr 1fr .85fr 1fr 1fr 1fr 1fr auto;
  gap:12px;
  align-items:end;
}

label{
  color:#475569;
  font-size:12px;
  font-weight:900;
}

input,select{
  width:100%;
  height:40px;
  border:1px solid var(--line);
  border-radius:8px;
  padding:0 12px;
  margin-top:7px;
  outline:none;
  color:#334155;
  font-weight:700;
  background:#fff;
}

input:focus,select:focus{
  border-color:#93c5fd;
  box-shadow:0 0 0 3px rgba(59,130,246,.14);
}

.pdf-panel,.summary{
  padding:18px;
}

.pdf-panel h2,.summary h2{
  margin:0 0 15px;
  font-size:18px;
}

.pdf-preview{
  border:1px solid #d9e2ef;
  border-radius:10px;
  padding:14px;
  min-height:280px;
  background:#fff;
}

.doc{
  font-family:Arial,sans-serif;
  font-size:8px;
  color:#111827;
}

.doc-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  border-bottom:1px solid #d1d5db;
  padding-bottom:8px;
  margin-bottom:8px;
  gap:10px;
}

.doc-head b{
  color:#0f62fe;
  font-size:12px;
}

.doc-brand{
  display:flex;
  align-items:center;
  gap:6px;
}

.doc-brand img{
  width:24px;
  height:24px;
  object-fit:contain;
}

.doc-meta{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:5px;
  margin-bottom:8px;
}

.doc-client-card{
  display:grid;
  gap:3px;
  background:#f8fafc;
  border:1px solid #dbe4ef;
  border-radius:8px;
  padding:8px;
  margin-bottom:8px;
}

.doc-client-card b{
  color:#0f62fe;
  font-size:9px;
  text-transform:uppercase;
}

.doc-client-card span{
  font-size:11px;
  font-weight:800;
  color:#111827;
}

.doc-client-card small{
  color:#475569;
  font-size:8px;
  line-height:1.25;
}

.doc-observations{
  background:#fff7ed;
  border:1px solid #fed7aa;
  border-radius:8px;
  color:#7c2d12;
  font-size:8px;
  line-height:1.35;
  padding:7px 8px;
  margin-bottom:8px;
}

.mini th,.mini td{
  font-size:7px;
  padding:4px 3px;
  border:1px solid #d1d5db;
}

.mini th{
  background:#f3f4f6;
}

.doc-total{
  text-align:right;
  margin-top:9px;
}

.doc p{
  text-align:center;
  margin-top:18px;
  font-weight:700;
}

.summary-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:15px;
}

.period-label{
  color:#64748b;
  font-size:13px;
  font-weight:900;
  background:#f8fafc;
  border:1px solid var(--line);
  border-radius:999px;
  padding:7px 10px;
}

.summary-numbers{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  padding-bottom:16px;
  margin-bottom:16px;
  border-bottom:1px solid var(--line);
}

.summary-numbers div + div{
  border-left:1px solid var(--line);
  padding-left:14px;
}

.summary-numbers span{
  display:block;
  color:#64748b;
  font-weight:900;
  font-size:13px;
  margin-bottom:6px;
}

.summary-numbers b{
  display:block;
  font-size:18px;
  margin-bottom:5px;
}

.summary h3{
  font-size:15px;
  margin:15px 0 10px;
}

.donut-row{
  display:grid;
  grid-template-columns:92px 1fr;
  align-items:center;
  gap:14px;
}

.donut{
  width:86px;
  height:86px;
  border-radius:50%;
  background:#e2e8f0;
  position:relative;
}

.donut:after{
  content:"";
  position:absolute;
  inset:18px;
  background:#fff;
  border-radius:50%;
}

.donut-row p{
  font-size:13px;
  color:#475569;
  font-weight:800;
}

.dot{
  display:inline-block;
  width:9px;
  height:9px;
  border-radius:50%;
  margin-right:7px;
}

.blue-dot{background:#0f62fe}
.green-dot{background:#22c55e}

.empty-chart{
  color:#64748b;
  font-weight:800;
  border:1px dashed var(--line);
  border-radius:10px;
  padding:20px;
  line-height:1.45;
  background:#f8fafc;
}

.modal-backdrop{
  position:fixed;
  inset:0;
  background:rgba(15,23,42,.45);
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
  z-index:50;
}

.modal-backdrop.show{display:flex}

.modal{
  width:min(720px,100%);
  background:#fff;
  border-radius:12px;
  box-shadow:0 25px 80px rgba(2,8,23,.3);
  padding:24px;
}

.modal h2{margin:0 0 18px}

.modal-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}

.modal-actions{
  display:flex;
  justify-content:flex-end;
  gap:10px;
  margin-top:20px;
}

.toast{
  position:fixed;
  right:24px;
  bottom:24px;
  background:#071628;
  color:#fff;
  border-radius:10px;
  padding:14px 18px;
  font-weight:900;
  box-shadow:0 16px 40px rgba(2,8,23,.25);
  display:none;
  z-index:80;
}

.toast.show{
  display:block;
  animation:toast .2s ease;
}

.app-content{
  align-items:start;
}

.wide{
  grid-column:1 / -1;
}

.state-panel{
  grid-column:1 / -1;
  padding:28px;
  color:#475569;
  font-weight:900;
}

.error-state{
  color:#b91c1c;
  background:#fff7f7;
}

.muted{
  color:#64748b;
  font-weight:700;
  line-height:1.5;
}

.dashboard-grid{
  display:grid;
  grid-template-columns:180px 1fr;
  gap:20px;
  padding:22px;
  align-items:center;
}

.donut.big{
  width:150px;
  height:150px;
}

.list-block{
  display:grid;
  gap:12px;
}

.line-item{
  border:1px solid var(--line);
  border-radius:10px;
  padding:14px;
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
}

.line-item span{
  color:#64748b;
  font-weight:800;
}

.detail-box{
  display:grid;
  gap:12px;
  padding:18px;
}

.detail-box div{
  border:1px solid var(--line);
  border-radius:10px;
  padding:12px;
  display:grid;
  gap:5px;
}

.login-screen{
  position:fixed;
  inset:0;
  z-index:120;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:34px;
  overflow:auto;
  background:
    radial-gradient(circle at 16% 18%,rgba(34,197,94,.24),transparent 28%),
    radial-gradient(circle at 82% 8%,rgba(15,98,254,.28),transparent 30%),
    linear-gradient(135deg,#071628 0%,#0f2d5c 46%,#eef7f2 100%);
}

.login-shell{
  width:min(1180px,100%);
  min-height:min(760px,calc(100svh - 68px));
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(360px,.8fr);
  background:rgba(255,255,255,.96);
  border:1px solid rgba(255,255,255,.38);
  border-radius:28px;
  overflow:hidden;
  box-shadow:0 34px 100px rgba(2,8,23,.28);
  animation:loginShellIn .5s ease both;
}

.company-hero{
  position:relative;
  min-height:100%;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:44px;
  padding:54px;
  color:#fff;
  background:
    linear-gradient(90deg,rgba(7,22,40,.96),rgba(7,22,40,.68)),
    linear-gradient(135deg,#071628,#0f62fe 58%,#16a34a);
}

.company-hero::after{
  content:"";
  position:absolute;
  right:-120px;
  bottom:-130px;
  width:420px;
  height:420px;
  border-radius:50%;
  border:70px solid rgba(255,255,255,.08);
  pointer-events:none;
}

.company-mark{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  gap:14px;
  font-size:15px;
  font-weight:1000;
}

.company-mark .brand-icon{
  width:54px;
  height:54px;
  border-color:rgba(255,255,255,.78);
  box-shadow:0 16px 38px rgba(0,0,0,.18);
}

.company-mark .public-client-logo{
  width:auto;
  min-width:54px;
  max-width:170px;
  padding:6px 10px;
  background:#fff;
}

.company-mark .public-client-logo img{
  width:auto;
  max-width:150px;
  height:100%;
  object-fit:contain;
  padding:0;
}

.company-copy{
  position:relative;
  z-index:1;
  max-width:620px;
}

.company-eyebrow{
  display:block;
  margin-bottom:18px;
  color:#bfdbfe;
  font-size:12px;
  font-weight:1000;
  text-transform:uppercase;
}

.company-copy h1{
  margin:0;
  max-width:560px;
  font-size:64px;
  line-height:.95;
  letter-spacing:0;
}

.company-copy p{
  max-width:570px;
  margin:22px 0 0;
  color:#dbeafe;
  font-size:18px;
  line-height:1.6;
  font-weight:700;
}

.hero-actions{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:14px;
  margin-top:30px;
}

.hero-link{
  min-height:46px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0 20px;
  border-radius:8px;
  text-decoration:none;
  font-size:14px;
  font-weight:1000;
  transition:.18s ease;
}

.hero-link.primary{
  background:#fff;
  color:#0f2d5c;
}

.hero-link.secondary{
  border:1px solid rgba(255,255,255,.42);
  color:#fff;
}

.hero-link:hover{
  transform:translateY(-2px);
}

.hero-note{
  color:#cbd5e1;
  font-size:13px;
  font-weight:800;
}

.company-highlights{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}

.company-highlights div{
  border-top:1px solid rgba(255,255,255,.2);
  padding-top:16px;
  transition:.18s ease;
}

.company-highlights div:hover{
  transform:translateY(-3px);
  border-color:rgba(255,255,255,.52);
}

.company-highlights strong,
.company-highlights span{
  display:block;
}

.company-highlights strong{
  margin-bottom:8px;
  font-size:15px;
  font-weight:1000;
}

.company-highlights span{
  color:#cbd5e1;
  font-size:13px;
  line-height:1.45;
  font-weight:700;
}

.login-side{
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:18px;
  padding:42px;
  background:
    linear-gradient(180deg,rgba(248,251,255,.86),#fff);
}

.process-preview{
  display:grid;
  gap:10px;
  padding:18px;
  border:1px solid #dbeafe;
  border-radius:18px;
  background:#f8fbff;
  animation:previewIn .65s ease .12s both;
}

.quote-card{
  gap:14px;
}

.quote-card h2,
.public-quote-dialog h2{
  margin:0;
  color:#0f172a;
  font-size:22px;
  letter-spacing:0;
}

.public-quote-modal{
  position:fixed;
  inset:0;
  z-index:180;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:22px;
  background:rgba(2,8,23,.62);
  backdrop-filter:blur(10px);
}

.public-quote-dialog{
  position:relative;
  width:min(760px,100%);
  max-height:calc(100svh - 44px);
  overflow:auto;
  display:grid;
  gap:18px;
  padding:0;
  border-radius:22px;
  background:#fff;
  box-shadow:0 32px 90px rgba(2,8,23,.36);
  animation:previewIn .18s ease both;
}

.quote-dialog-head{
  padding:30px 34px 24px;
  color:#fff;
  background:
    linear-gradient(135deg,rgba(7,22,40,.98),rgba(15,45,92,.94)),
    linear-gradient(135deg,#071628,#0f62fe);
}

.quote-dialog-head .preview-label{
  color:#bfdbfe;
}

.quote-dialog-head h2{
  color:#fff;
  font-size:32px;
  line-height:1.05;
}

.public-quote-dialog p,
.quote-dialog-head p{
  margin:0;
}

.quote-dialog-head p{
  max-width:560px;
  margin-top:10px;
  color:#dbeafe;
  font-size:15px;
  line-height:1.55;
  font-weight:800;
}

.quote-dialog-body{
  display:grid;
  grid-template-columns:230px minmax(0,1fr);
  gap:20px;
  padding:24px 34px 30px;
}

.quote-help{
  display:grid;
  align-content:start;
  gap:10px;
}

.quote-help div{
  padding:13px;
  border:1px solid #dbeafe;
  border-radius:12px;
  background:#f8fbff;
}

.quote-help b,
.quote-help span{
  display:block;
}

.quote-help b{
  margin-bottom:5px;
  color:#0f172a;
  font-size:13px;
  font-weight:1000;
}

.quote-help span{
  color:#64748b;
  font-size:12px;
  line-height:1.45;
  font-weight:800;
}

.public-quote-close{
  position:absolute;
  top:14px;
  right:14px;
  width:34px;
  height:34px;
  border:1px solid rgba(255,255,255,.24);
  border-radius:8px;
  background:rgba(255,255,255,.16);
  color:#fff;
  cursor:pointer;
  font-size:22px;
  line-height:1;
  font-weight:900;
}

.public-quote-close:hover{
  background:rgba(255,255,255,.26);
}

.quote-form{
  display:grid;
  gap:12px;
}

.quote-form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}

.quote-form label{
  font-size:11px;
}

.quote-form label span{
  color:#94a3b8;
  font-weight:800;
}

.quote-form textarea{
  min-height:116px;
  resize:vertical;
}

.quote-privacy{
  display:block;
  color:#64748b;
  font-size:12px;
  font-weight:800;
  line-height:1.45;
}

.quote-status{
  min-height:0;
  color:#64748b;
  font-size:12px;
  font-weight:900;
  line-height:1.45;
  border-radius:10px;
}

.quote-status.success{
  padding:10px 12px;
  background:#ecfdf5;
  color:#047857;
}

.quote-status.error{
  padding:10px 12px;
  background:#fef2f2;
  color:#b91c1c;
}

.preview-label{
  color:#1d4ed8;
  font-size:11px;
  font-weight:1000;
  text-transform:uppercase;
}

.preview-step{
  display:flex;
  align-items:center;
  gap:12px;
  color:#475569;
  font-size:13px;
  font-weight:900;
}

.preview-step b{
  width:36px;
  height:36px;
  display:grid;
  place-items:center;
  border-radius:8px;
  background:#e2e8f0;
  color:#334155;
  font-size:12px;
}

.preview-step.active b{
  background:#0f62fe;
  color:#fff;
}

.login-panel{
  width:100%;
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  box-shadow:0 18px 52px rgba(15,23,42,.12);
  padding:30px;
  animation:previewIn .65s ease .2s both;
}

.login-brand{
  margin-bottom:22px;
}

.login-brand h2{
  margin:0 0 5px;
  font-size:26px;
  letter-spacing:0;
}

.login-brand p{
  margin:0;
  color:#64748b;
  font-weight:700;
}

.login-form{
  display:grid;
  gap:14px;
}

.login-hint{
  background:#f8fafc;
  border:1px solid var(--line);
  border-radius:8px;
  color:#475569;
  font-size:12px;
  font-weight:800;
  line-height:1.45;
  padding:10px 12px;
}

.login-error{
  min-height:18px;
  color:#b91c1c;
  font-size:13px;
  font-weight:900;
}

@keyframes loginShellIn{
  from{opacity:0;transform:translateY(18px) scale(.985)}
  to{opacity:1;transform:translateY(0) scale(1)}
}

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

.role-help{
  margin-top:14px;
  background:#f8fafc;
  border:1px solid var(--line);
  border-radius:8px;
  color:#475569;
  font-size:13px;
  font-weight:800;
  line-height:1.5;
  padding:12px;
}

.check-row{
  display:flex;
  align-items:center;
  gap:10px;
  min-height:40px;
  margin-top:20px;
}

.check-row input{
  width:18px;
  height:18px;
  margin:0;
}

.detail-box b{
  color:#0f172a;
}

.detail-box span{
  color:#475569;
  font-weight:800;
}

.pill.closed{
  background:#e2e8f0;
  color:#334155;
}

.selected-row td{
  background:#eff6ff;
}

.compact{
  min-height:auto;
  margin:0 18px 10px;
  overflow-x:auto;
}

.import-zone{
  grid-column:1 / -1;
}

.import-result{
  padding:14px 18px;
  border-bottom:1px solid var(--line);
  display:flex;
  justify-content:space-between;
  gap:12px;
  color:#334155;
  align-items:center;
  background:#f8fafc;
}

.import-result small{
  display:block;
  color:#64748b;
  font-weight:800;
  margin-top:4px;
}

.import-result span{
  background:#dbeafe;
  color:#0f62fe;
  border-radius:999px;
  padding:6px 10px;
  font-size:12px;
  font-weight:900;
  white-space:nowrap;
}

.import-result.success{
  background:#f0fdf4;
}

.import-result.warning{
  background:#fffbeb;
}

.import-guide{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:16px 18px;
  background:#f8fafc;
  border-bottom:1px solid var(--line);
  color:#475569;
  font-weight:800;
}

.import-guide span{
  color:#64748b;
  font-size:13px;
}

.text-preview{
  border-bottom:1px solid var(--line);
  background:#fff;
}

.text-preview summary{
  cursor:pointer;
  padding:12px 18px;
  color:#334155;
  font-weight:900;
}

.text-preview pre{
  margin:0;
  max-height:220px;
  overflow:auto;
  padding:0 18px 16px;
  color:#475569;
  white-space:pre-wrap;
  font:12px/1.55 Consolas,Monaco,monospace;
}

.settings-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  align-items:end;
}

.settings-logo-row{
  display:grid;
  grid-template-columns:72px minmax(0,1fr);
  gap:16px;
  align-items:center;
  padding:14px;
  margin-bottom:18px;
  border:1px solid var(--line);
  border-radius:10px;
  background:#f8fafc;
}

.settings-logo-row b{
  display:block;
  margin-bottom:4px;
}

.settings-logo-row p{
  color:#64748b;
  font-size:13px;
  font-weight:800;
  line-height:1.4;
  margin:0 0 10px;
}

.logo-preview{
  width:64px;
  height:64px;
  border:1px solid var(--line);
  border-radius:10px;
  background:#fff;
  display:grid;
  place-items:center;
  overflow:hidden;
}

.logo-preview img{
  width:100%;
  height:100%;
  object-fit:contain;
  padding:7px;
}

td input,td select{
  min-width:120px;
  margin-top:0;
}

td input[name="descricao"]{
  min-width:240px;
}

.row-actions .btn{
  min-height:32px;
  white-space:nowrap;
}

.modal{
  max-height:calc(100vh - 48px);
  overflow:auto;
}

@keyframes toast{
  from{opacity:.2;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}

@media(max-width:1350px){
  .stats{grid-template-columns:repeat(2,1fr)}
  .content{grid-template-columns:1fr}
  .side-col{display:grid;grid-template-columns:1fr 1fr}
  .upload-zone{grid-template-columns:150px 1fr}
  .ocr-box{grid-column:1 / -1}
  .manual-grid{grid-template-columns:repeat(3,1fr)}
}

@media(max-width:1100px){
  .login-screen{
    align-items:flex-start;
  }

  .login-shell{
    grid-template-columns:1fr;
    min-height:0;
  }

  .company-hero{
    min-height:520px;
  }

  .company-copy h1{
    font-size:50px;
  }

  .login-side{
    display:grid;
    grid-template-columns:1fr 1fr;
    align-items:start;
  }
}

@media(max-width:900px){
  .app{grid-template-columns:1fr}
  .sidebar{display:none}
  .topbar{height:auto;flex-wrap:wrap;padding:16px}
  .topbar h1{font-size:20px}
  .search{order:5;max-width:none;width:100%}
  .content{padding:16px}
  .stats,.side-col{grid-template-columns:1fr}
  .upload-zone{grid-template-columns:1fr;text-align:center}
  .manual-grid,.modal-grid{grid-template-columns:1fr}
  .dashboard-grid,.settings-grid{grid-template-columns:1fr}
  .line-item{display:grid}
  table{min-width:850px}
  .company-hero{min-height:0}
  .company-highlights{grid-template-columns:1fr}
  .login-side{display:flex}
}

@media print{
  body *{visibility:hidden}
  .doc,.doc *{visibility:visible}
  .doc{
    position:absolute;
    left:0;
    top:0;
    width:100%;
    padding:20px;
  }
}


html{
  -webkit-text-size-adjust:100%;
  scroll-behavior:smooth;
}

body{
  min-width:320px;
}

.main{
  min-width:0;
  overflow-x:hidden;
}

button,
a.btn,
input,
select,
textarea{
  touch-action:manipulation;
}

textarea{
  width:100%;
  border:1px solid var(--line);
  border-radius:8px;
  padding:12px;
  margin-top:7px;
  outline:none;
  color:#334155;
  font-weight:700;
  background:#fff;
  resize:vertical;
}

.mobile-menu-btn{
  display:inline-flex;
}

.sidebar-scrim{
  display:none;
}

@media(min-width:1025px){
  .app.sidebar-collapsed{
    grid-template-columns:82px minmax(0,1fr);
  }

  .app.sidebar-collapsed .sidebar{
    padding:18px 10px;
  }

  .app.sidebar-collapsed .brand{
    justify-content:center;
    padding-bottom:16px;
  }

  .app.sidebar-collapsed .brand h1,
  .app.sidebar-collapsed .menu-item span,
  .app.sidebar-collapsed .sidebar-footer strong{
    display:none;
  }

  .app.sidebar-collapsed .brand-icon{
    width:44px;
    height:44px;
  }

  .app.sidebar-collapsed .menu{
    margin-top:18px;
    gap:8px;
    align-items:center;
  }

  .app.sidebar-collapsed .menu-item{
    width:48px;
    height:48px;
    padding:0;
    justify-content:center;
    gap:0;
    font-size:18px;
  }

  .app.sidebar-collapsed .sidebar-footer{
    align-items:center;
    text-align:center;
    padding-top:12px;
  }

  .app.sidebar-collapsed .sidebar-footer small{
    font-size:10px;
    line-height:1.2;
  }
}

.table-wrap{
  -webkit-overflow-scrolling:touch;
  scrollbar-width:thin;
}

.table-wrap::after{
  content:"";
  display:block;
  height:1px;
}

.row-actions,
.panel-actions,
.modal-actions{
  flex-wrap:wrap;
}

.panel,
.stat-card,
.upload-zone,
.login-panel,
.modal{
  max-width:100%;
}

img,
svg,
video,
canvas{
  max-width:100%;
}

@media(max-width:1200px){
  .app{
    grid-template-columns:236px minmax(0,1fr);
  }

  .sidebar{
    padding:20px 14px;
  }

  .topbar{
    padding:0 20px;
    gap:14px;
  }

  .content{
    padding:20px;
    grid-template-columns:minmax(0,1fr);
  }

  .main-col,
  .side-col{
    min-width:0;
  }

  .stats{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  .side-col{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  .upload-zone{
    grid-template-columns:120px minmax(0,1fr) 260px;
  }

  .manual-grid{
    grid-template-columns:repeat(4,minmax(0,1fr));
  }
}

@media(max-width:1024px){
  .app{
    display:block;
    min-height:100vh;
  }

  .app.sidebar-collapsed{
    display:block;
  }

  .mobile-menu-btn{
    display:inline-flex;
  }

  .sidebar{
    display:flex!important;
    position:fixed;
    inset:0 auto 0 0;
    width:min(86vw,320px);
    height:100dvh;
    min-height:100vh;
    z-index:70;
    transform:translateX(-105%);
    transition:transform .22s ease;
    overflow-y:auto;
    box-shadow:24px 0 60px rgba(2,8,23,.28);
  }

  .app.sidebar-open .sidebar{
    transform:translateX(0);
  }

  .sidebar-scrim{
    position:fixed;
    inset:0;
    z-index:60;
    background:rgba(2,8,23,.48);
    opacity:0;
    pointer-events:none;
    transition:opacity .22s ease;
  }

  .app.sidebar-open .sidebar-scrim{
    display:block;
    opacity:1;
    pointer-events:auto;
  }

  body.menu-open{
    overflow:hidden;
  }

  .main{
    min-height:100vh;
  }

  .topbar{
    min-height:70px;
    height:auto;
    position:sticky;
    padding:12px 16px;
    display:flex;
    flex-wrap:wrap;
    align-items:center;
  }

  .topbar h1{
    font-size:20px;
    flex:1;
    min-width:0;
    overflow:hidden;
    text-overflow:ellipsis;
  }

  .search{
    order:10;
    flex:1 0 100%;
    width:100%;
    max-width:none;
    margin-left:0;
  }

  .search input{
    height:44px;
  }

  .content{
    padding:16px;
    display:grid;
    grid-template-columns:minmax(0,1fr);
  }

  .stats,
  .side-col{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  .upload-zone{
    grid-template-columns:96px minmax(0,1fr);
    padding:18px;
  }

  .ocr-box{
    grid-column:1 / -1;
  }

  .manual-grid,
  .modal-grid,
  .settings-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  .dashboard-grid{
    grid-template-columns:150px minmax(0,1fr);
  }

  .modal-backdrop{
    align-items:flex-start;
    padding:16px;
    overflow:auto;
  }

  .modal{
    margin:auto 0;
    max-height:calc(100dvh - 32px);
  }
}

@media(max-width:760px){
  input,
  select,
  textarea{
    font-size:16px;
  }

  .content{
    padding:12px;
    gap:14px;
  }

  .quote-dialog-body,
  .quote-form-grid{
    grid-template-columns:minmax(0,1fr);
  }

  .quote-help{
    grid-template-columns:minmax(0,1fr);
  }

  .stats,
  .side-col,
  .manual-grid,
  .modal-grid,
  .settings-grid,
  .dashboard-grid{
    grid-template-columns:minmax(0,1fr);
  }

  .stat-card{
    padding:16px;
    min-height:auto;
  }

  .stat-icon{
    width:48px;
    height:48px;
    font-size:22px;
  }

  .stat-card strong{
    font-size:22px;
  }

  .upload-zone{
    grid-template-columns:minmax(0,1fr);
    text-align:center;
    padding:18px;
  }

  .pdf-icon{
    width:74px;
    height:94px;
  }

  .panel-head{
    align-items:flex-start;
    flex-direction:column;
    padding:16px;
  }

  .panel-head h2{
    width:100%;
    flex-wrap:wrap;
    align-items:flex-start;
  }

  .panel-actions,
  .modal-actions{
    width:100%;
    justify-content:stretch;
  }

  .panel-actions .btn,
  .modal-actions .btn{
    flex:1 1 180px;
  }

  .total-bar{
    display:grid;
    gap:8px;
    text-align:left;
  }

  .table-wrap.mobile-card-table{
    overflow:visible;
    padding:12px;
  }

  .table-wrap.mobile-card-table table,
  .table-wrap.mobile-card-table thead,
  .table-wrap.mobile-card-table tbody,
  .table-wrap.mobile-card-table th,
  .table-wrap.mobile-card-table td,
  .table-wrap.mobile-card-table tr{
    display:block;
    width:100%;
    min-width:0;
  }

  .table-wrap.mobile-card-table table{
    border-collapse:separate;
    border-spacing:0;
  }

  .table-wrap.mobile-card-table thead{
    position:absolute;
    width:1px;
    height:1px;
    overflow:hidden;
    clip:rect(0 0 0 0);
    white-space:nowrap;
  }

  .table-wrap.mobile-card-table tbody{
    display:grid;
    gap:12px;
  }

  .table-wrap.mobile-card-table tbody tr{
    border:1px solid var(--line);
    border-radius:12px;
    background:#fff;
    box-shadow:0 8px 18px rgba(15,23,42,.04);
    overflow:hidden;
  }

  .table-wrap.mobile-card-table tbody tr:hover td{
    background:#fff;
  }

  .table-wrap.mobile-card-table td{
    min-height:44px;
    padding:11px 12px;
    border-bottom:1px solid #edf2f7;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:14px;
    text-align:right;
    overflow-wrap:anywhere;
  }

  .table-wrap.mobile-card-table td:last-child{
    border-bottom:0;
  }

  .table-wrap.mobile-card-table td::before{
    content:attr(data-label);
    color:#64748b;
    font-size:12px;
    font-weight:900;
    text-align:left;
    min-width:92px;
    max-width:42%;
  }

  .table-wrap.mobile-card-table td[colspan]{
    display:block;
    text-align:center;
  }

  .table-wrap.mobile-card-table td[colspan]::before,
  .table-wrap.mobile-card-table td[data-label=""]::before{
    display:none;
  }

  .table-wrap.mobile-card-table td input,
  .table-wrap.mobile-card-table td select{
    min-width:0;
    width:100%;
    margin-top:0;
  }

  .table-wrap.mobile-card-table td input[name="descricao"]{
    min-width:0;
  }

  .table-wrap.mobile-card-table .row-actions{
    width:100%;
    justify-content:flex-end;
  }

  .table-wrap.mobile-card-table .btn{
    min-height:38px;
  }

  .mini{
    min-width:0!important;
  }

  .pdf-preview,
  .compact{
    overflow-x:auto;
  }

  .compact{
    margin:0 12px 10px;
  }

  .line-item{
    display:grid;
    justify-content:stretch;
  }

  .detail-box{
    padding:14px;
  }

  .settings-logo-row{
    grid-template-columns:minmax(0,1fr);
    text-align:center;
  }

  .logo-preview{
    margin:0 auto;
  }

  .toast{
    left:12px;
    right:12px;
    bottom:12px;
    text-align:center;
  }
}

@media(max-width:560px){
  .login-screen{
    padding:12px;
    align-items:flex-start;
  }

  .login-shell{
    min-height:0;
    border-radius:18px;
  }

  .company-hero,
  .login-side{
    padding:22px;
  }

  .login-side{
    display:flex;
  }

  .company-copy h1{
    font-size:34px;
  }

  .company-copy p{
    font-size:14px;
    line-height:1.55;
  }

  .company-highlights{
    grid-template-columns:1fr;
    gap:12px;
  }

  .process-preview{
    padding:14px;
  }

  .public-quote-modal{
    padding:10px;
    align-items:flex-end;
  }

  .public-quote-dialog{
    width:100%;
    max-height:92svh;
    border-radius:18px 18px 0 0;
  }

  .quote-dialog-head{
    padding:24px 20px 20px;
  }

  .quote-dialog-head h2{
    font-size:26px;
  }

  .quote-dialog-body{
    padding:18px 20px 24px;
  }

  .login-panel{
    padding:22px;
  }

  .login-brand{
    margin-bottom:16px;
  }

  .login-brand h2{
    font-size:22px;
  }

  .topbar{
    gap:10px;
    padding:10px 12px;
  }

  .hamb{
    width:40px;
    min-width:40px;
    height:40px;
    display:inline-grid;
    place-items:center;
    border-radius:10px;
    background:#f8fafc;
    border:1px solid var(--line);
    font-size:19px;
  }

  .topbar h1{
    order:3;
    flex:1 0 calc(100% - 104px);
    font-size:18px;
  }

  .user-actions{
    margin-left:auto;
    gap:8px;
  }

  .avatar{
    width:38px;
    height:38px;
    font-size:13px;
  }

  .user-name{
    display:none;
  }

  .compact-btn{
    padding:0 10px;
  }

  .search kbd{
    display:none;
  }

  .search input{
    padding-right:14px;
  }

  .content{
    padding:10px;
  }

  .panel-head h2{
    font-size:16px;
  }

  .btn,
  a.btn{
    min-height:44px;
    width:100%;
  }

  .topbar .btn{
    width:auto;
    min-height:40px;
  }

  .row-actions .btn,
  .row-actions .icon-action{
    width:auto;
  }

  .icon-action{
    width:38px;
    height:38px;
  }

  .modal-backdrop{
    padding:10px;
  }

  .modal{
    width:100%;
    padding:18px;
    border-radius:10px;
  }

  .modal-actions{
    display:grid;
    grid-template-columns:1fr;
  }

  .check-row{
    align-items:flex-start;
  }

  .upload-text h2{
    font-size:18px;
  }

  .summary-numbers{
    grid-template-columns:minmax(0,1fr);
  }

  .donut-row{
    align-items:flex-start;
  }

  .table-wrap.mobile-card-table td{
    display:grid;
    grid-template-columns:minmax(0,1fr);
    text-align:left;
  }

  .table-wrap.mobile-card-table td::before{
    max-width:none;
    min-width:0;
  }

  .table-wrap.mobile-card-table .row-actions{
    justify-content:flex-start;
  }
}

@media(max-width:380px){
  .brand h1{
    font-size:15px;
  }

  .sidebar{
    width:92vw;
  }

  .topbar h1{
    font-size:16px;
  }

  .stat-card{
    align-items:flex-start;
  }

  .stat-card strong{
    font-size:20px;
  }
}


:root{
  --surface:#ffffff;
  --surface-soft:#f8fbff;
  --ink:#0b1220;
  --brand-grad:linear-gradient(135deg,#0f62fe 0%,#6d5dfc 52%,#22c55e 100%);
}

.modern-panel{
  border:1px solid rgba(148,163,184,.28);
  box-shadow:0 18px 48px rgba(15,23,42,.08);
}

.budget-hero{
  grid-column:1 / -1;
  background:
    radial-gradient(circle at 12% 18%,rgba(255,255,255,.28),transparent 24%),
    linear-gradient(135deg,#071628 0%,#0f2d5c 44%,#0f62fe 100%);
  border-radius:22px;
  color:#fff;
  padding:28px;
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:22px;
  align-items:center;
  box-shadow:0 22px 60px rgba(15,23,42,.20);
  overflow:hidden;
  position:relative;
}

.budget-hero:after{
  content:"";
  position:absolute;
  inset:auto -80px -120px auto;
  width:260px;
  height:260px;
  border-radius:50%;
  background:rgba(255,255,255,.10);
}

.budget-hero h2{
  margin:8px 0;
  font-size:clamp(24px,3vw,38px);
  line-height:1.08;
  letter-spacing:-.035em;
}

.budget-hero p{
  margin:0;
  color:#dbeafe;
  font-weight:700;
  max-width:780px;
}

.eyebrow{
  color:#93c5fd;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:11px;
  font-weight:1000;
}

.budget-hero-actions{
  display:grid;
  grid-template-columns:repeat(2,minmax(130px,1fr));
  gap:12px;
  align-items:stretch;
  min-width:320px;
  position:relative;
  z-index:1;
}

.budget-hero-actions > div{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.22);
  border-radius:16px;
  padding:16px;
  backdrop-filter:blur(10px);
}

.budget-hero-actions b{
  display:block;
  font-size:22px;
  line-height:1.1;
}

.budget-hero-actions span{
  color:#dbeafe;
  font-weight:800;
  font-size:12px;
}

.budget-hero-actions .btn{
  grid-column:1 / -1;
  min-height:48px;
  border-radius:14px;
  background:#fff;
  color:#0f62fe;
}

.filter-panel{
  grid-column:1 / -1;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(148,163,184,.32);
  border-radius:18px;
  padding:16px;
  box-shadow:0 14px 40px rgba(15,23,42,.07);
  display:grid;
  grid-template-columns:minmax(220px,1.7fr) minmax(160px,.8fr) minmax(150px,.7fr) minmax(150px,.7fr) auto;
  gap:12px;
  align-items:end;
}

.filter-panel label{
  display:grid;
  gap:6px;
  color:#475569;
  font-size:12px;
  font-weight:1000;
}

.filter-panel input,
.filter-panel select{
  min-height:44px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#f8fafc;
  padding:0 12px;
  font-weight:800;
  outline:none;
}

.filter-panel input:focus,
.filter-panel select:focus{
  border-color:#0f62fe;
  box-shadow:0 0 0 4px rgba(15,98,254,.10);
}

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

.compact-stats{
  gap:14px;
}

.compact-stats .stat-card{
  min-height:92px;
  padding:16px;
}

.budget-table tr{
  cursor:pointer;
}

.budget-table td:first-child{
  color:#0f62fe;
}

.budget-list-col{
  min-width:0;
}

.budget-side{
  position:sticky;
  top:92px;
  align-self:start;
}

.budget-detail-panel{
  padding:0;
  overflow:hidden;
}

.budget-preview-card{
  display:grid;
  gap:16px;
  padding:18px;
}

.budget-preview-top{
  background:linear-gradient(135deg,#f8fbff,#eef6ff);
  border:1px solid #dbeafe;
  border-radius:18px;
  padding:16px;
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  gap:14px;
  align-items:center;
}

.client-avatar{
  width:54px;
  height:54px;
  border-radius:18px;
  background:var(--brand-grad);
  color:#fff;
  display:grid;
  place-items:center;
  font-weight:1000;
  box-shadow:0 12px 28px rgba(15,98,254,.25);
}

.budget-preview-top h2{
  margin:4px 0;
  font-size:20px;
  letter-spacing:-.02em;
}

.budget-preview-top p{
  margin:0;
  color:#64748b;
  font-weight:800;
}

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

.budget-metrics div{
  border:1px solid var(--line);
  border-radius:14px;
  padding:12px;
  background:#fff;
}

.budget-metrics b{
  display:block;
  color:#0f172a;
  font-size:16px;
}

.budget-metrics span{
  display:block;
  margin-top:4px;
  color:#64748b;
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
}

.modern-detail{
  padding:0;
  grid-template-columns:1fr 1fr;
}

.modern-detail div{
  background:#f8fafc;
}

.modern-detail b{
  color:#64748b;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.06em;
}

.modern-detail span{
  overflow-wrap:anywhere;
}

.modern-budget-items{
  min-height:0;
  max-height:320px;
  overflow:auto;
  border-radius:16px;
}

.modern-budget-items .mini th,
.modern-budget-items .mini td{
  font-size:11px;
  padding:8px;
}

.budget-actions-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}

.budget-actions-grid .btn.full{
  margin:0;
}

.btn.whatsapp{
  background:#16a34a;
  color:#fff;
  box-shadow:0 10px 22px rgba(22,163,74,.22);
}

.import-guide,
.import-result{
  border-radius:16px;
}

.import-zone{
  border-style:solid;
  border-color:#bfdbfe;
  background:linear-gradient(135deg,#fff,#f8fbff);
}

.report-hero{
  background:
    radial-gradient(circle at 12% 18%,rgba(255,255,255,.30),transparent 22%),
    linear-gradient(135deg,#111827 0%,#4c1d95 48%,#0f62fe 100%);
}

.compact-modal{
  max-width:520px;
}

@media (max-width:1180px){
  .filter-panel{
    grid-template-columns:1fr 1fr;
  }
  .filter-actions{
    justify-content:flex-start;
  }
  .budget-side{
    position:static;
  }
}

@media (max-width:900px){
  .budget-hero{
    grid-template-columns:1fr;
    padding:22px;
  }
  .budget-hero-actions{
    min-width:0;
    grid-template-columns:1fr 1fr;
  }
  .budget-metrics{
    grid-template-columns:1fr 1fr;
  }
  .budget-preview-top{
    grid-template-columns:auto 1fr;
  }
  .budget-preview-top .pill{
    grid-column:1 / -1;
    justify-self:start;
  }
}

@media (max-width:640px){
  .budget-hero-actions,
  .filter-panel,
  .budget-actions-grid,
  .modern-detail{
    grid-template-columns:1fr;
  }
  .budget-hero{
    border-radius:16px;
  }
  .budget-hero h2{
    font-size:24px;
  }
  .budget-preview-card{
    padding:12px;
  }
  .budget-preview-top{
    grid-template-columns:1fr;
    text-align:left;
  }
  .client-avatar{
    width:48px;
    height:48px;
  }
}


.manual-avulso-panel .panel-head{
  align-items:flex-start;
}

.manual-avulso-panel .panel-head .muted{
  margin:.35rem 0 0;
  max-width:760px;
}

.manual-mode,
.compact-check{
  border:1px dashed #bfdbfe;
  background:#eff6ff;
  border-radius:12px;
  padding:10px 12px;
}

.manual-mode span,
.compact-check span{
  color:#0f172a;
  font-weight:900;
}

.compact-check{
  max-width:max-content;
  margin:8px auto 10px;
}

.item-origin-note{
  display:block;
  width:max-content;
  max-width:100%;
  margin-top:5px;
  padding:3px 8px;
  border-radius:999px;
  background:#dbeafe;
  color:#1d4ed8;
  font-size:10px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.04em;
}

.item-origin-note.avulso{
  background:#fef3c7;
  color:#92400e;
}

.import-options{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px 14px;
  margin-bottom:14px;
}

.import-options .check-row{
  margin:0;
}

@media (max-width:640px){
  .manual-avulso-panel .panel-head{
    gap:12px;
  }
  .manual-avulso-panel .panel-head .btn{
    width:100%;
  }
  .compact-check{
    max-width:100%;
  }
  .import-options{
    display:grid;
  }
}

:root{
  --space-1:4px;
  --space-2:8px;
  --space-3:12px;
  --space-4:16px;
  --space-5:20px;
  --space-6:24px;
  --radius-sm:10px;
  --radius-md:16px;
  --radius-lg:22px;
  --brand-grad:linear-gradient(135deg,#0f62fe,#6d5dfc);
  --soft-blue:#eff6ff;
  --soft-green:#ecfdf5;
  --soft-orange:#fff7ed;
  --danger:#dc2626;
}

button:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[tabindex]:focus-visible{
  outline:3px solid rgba(15,98,254,.35);
  outline-offset:3px;
}

.btn,
.icon-action,
.menu-item,
.action-tile,
.filter-chip,
.budget-tabs button{
  min-height:44px;
}

.content > .dashboard-executive,
.content > .dashboard-chart-panel,
.content > .budget-workspace,
.content > .import-workspace,
.content > .report-grid,
.content > .filter-panel,
.content > .budget-hero{
  grid-column:1 / -1;
}

.modern-panel{
  border-radius:var(--radius-lg);
  box-shadow:0 18px 40px rgba(15,23,42,.08);
}

.dashboard-executive{
  display:grid;
  grid-template-columns:minmax(0,1.25fr) minmax(320px,.75fr);
  gap:20px;
  grid-column:1 / -1;
}

.dashboard-hero,
.current-budget-card{
  padding:24px;
}

.dashboard-hero{
  display:grid;
  gap:22px;
  background:linear-gradient(135deg,#ffffff,#f8fbff);
}

.dashboard-hero h2,
.workspace-hero h2,
.import-hero h2,
.report-hero h2{
  margin:6px 0 8px;
  letter-spacing:-.04em;
}

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

.action-tile{
  border:1px solid var(--line);
  border-radius:18px;
  background:#fff;
  padding:16px;
  display:grid;
  gap:6px;
  text-align:left;
  cursor:pointer;
  color:var(--text);
  box-shadow:0 8px 22px rgba(15,23,42,.05);
}

.action-tile:hover{
  transform:translateY(-1px);
  border-color:#bfdbfe;
}

.action-tile b{font-size:15px}
.action-tile span{color:var(--muted);font-weight:700;font-size:12px}
.primary-tile{background:var(--brand-grad);color:#fff;border:0}
.primary-tile span{color:#dbeafe}

.compact-preview-top{grid-template-columns:auto minmax(0,1fr) auto}
.dashboard-budget-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:16px;
}

.dashboard-metrics{margin-top:16px}
.online-alert{
  grid-column:1 / -1;
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  gap:16px;
  align-items:start;
  padding:18px;
  border:1px solid #bfdbfe;
  border-radius:14px;
  background:linear-gradient(135deg,#eff6ff,#ffffff);
  box-shadow:0 14px 32px rgba(15,98,254,.08);
}

.online-alert-clear{
  border-color:#d7e2ee;
  background:#f8fafc;
  box-shadow:none;
}

.online-alert-icon{
  width:44px;
  height:44px;
  border-radius:12px;
  display:grid;
  place-items:center;
  background:#0f62fe;
  color:#fff;
  font-weight:1000;
  font-size:24px;
}

.online-alert-clear .online-alert-icon{
  background:#16a34a;
}

.online-alert h2{
  margin:3px 0 6px;
  font-size:20px;
}

.online-alert p{
  margin:0;
  color:var(--muted);
  font-weight:700;
  line-height:1.45;
}

.online-alert-list{
  display:grid;
  gap:8px;
  margin-top:12px;
}

.online-alert-list button{
  border:1px solid #dbeafe;
  border-radius:10px;
  background:#fff;
  padding:10px 12px;
  text-align:left;
  cursor:pointer;
}

.online-alert-list button:hover{
  border-color:#93c5fd;
  background:#f8fbff;
}

.online-alert-list b,
.online-alert-list span{
  display:block;
}

.online-alert-list span{
  margin-top:3px;
  color:var(--muted);
  font-size:12px;
  line-height:1.4;
}

.online-alert-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  justify-content:flex-end;
}
.visual-grid{align-items:center}
.donut{position:relative;display:grid;place-items:center}
.donut::after{
  content:"";
  width:62%;
  height:62%;
  border-radius:50%;
  background:#fff;
  box-shadow:inset 0 0 0 1px var(--line);
}
.donut span{
  position:absolute;
  z-index:1;
  font-weight:1000;
  color:#0f172a;
}
.metric-line{border:1px solid var(--line);border-radius:14px;padding:12px;background:#fff}

.workspace-hero,
.import-hero{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:18px;
  align-items:end;
  background:linear-gradient(135deg,#0f172a,#0f62fe 58%,#6d5dfc);
  color:#fff;
  border:0;
}
.workspace-hero p,
.import-hero p,
.report-hero p{color:#dbeafe}
.workspace-hero .eyebrow,
.import-hero .eyebrow,
.report-hero .eyebrow{color:#bfdbfe}
.hero-metrics{
  grid-template-columns:repeat(2,minmax(120px,1fr));
}
.hero-metrics div{
  background:rgba(255,255,255,.13);
  border-color:rgba(255,255,255,.18);
  backdrop-filter:blur(8px);
}

.collapsible-filters{
  display:block;
  padding:0;
  overflow:hidden;
}
.collapsible-filters summary{
  list-style:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:16px 18px;
  cursor:pointer;
  font-weight:1000;
}
.collapsible-filters summary::-webkit-details-marker{display:none}
.collapsible-filters summary small{display:block;color:var(--muted);font-weight:700}
.filter-grid{
  display:grid;
  grid-template-columns:minmax(220px,2fr) repeat(3,minmax(140px,1fr)) auto;
  gap:12px;
  padding:0 18px 18px;
  align-items:end;
}
.filter-grid label{font-weight:900;color:#334155}
.filter-grid input,
.filter-grid select,
.modal input,
.modal select,
.modal textarea,
.import-destination select{
  min-height:44px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff;
  padding:10px 12px;
  width:100%;
  color:#0f172a;
}
.filter-chips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  padding:0 18px 18px;
}
.filter-chip{
  border:1px solid #bfdbfe;
  background:#eff6ff;
  color:#1d4ed8;
  border-radius:999px;
  padding:6px 12px;
  font-weight:900;
  cursor:pointer;
}

.budget-workspace{
  display:grid;
  grid-template-columns:minmax(320px,.88fr) minmax(0,1.35fr);
  gap:20px;
  align-items:start;
}
.budget-list-pane,
.budget-detail-pane{
  min-width:0;
  padding:0;
  overflow:hidden;
}
.sticky-head{
  position:sticky;
  top:74px;
  z-index:2;
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
  padding:18px;
}
.budget-card-list{
  display:grid;
  gap:12px;
  padding:16px;
  max-height:calc(100vh - 250px);
  overflow:auto;
}
.budget-card{
  border:1px solid var(--line);
  border-radius:18px;
  background:#fff;
  padding:14px;
  cursor:pointer;
  display:grid;
  gap:12px;
  transition:.18s ease;
}
.budget-card:hover{
  border-color:#93c5fd;
  box-shadow:0 14px 28px rgba(15,98,254,.08);
}
.budget-card.selected{
  border-color:#0f62fe;
  background:linear-gradient(135deg,#fff,#eff6ff);
  box-shadow:0 16px 30px rgba(15,98,254,.12);
}
.budget-card-top{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:12px;
  align-items:start;
}
.budget-card h3{margin:4px 0;font-size:16px;overflow-wrap:anywhere}
.budget-card p{margin:0;color:var(--muted);font-weight:700;font-size:12px}
.budget-number{font-size:12px;font-weight:1000;color:#1d4ed8;letter-spacing:.04em}
.budget-card-metrics{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
}
.budget-card-metrics span{
  border:1px solid var(--line);
  border-radius:12px;
  padding:10px;
  background:#f8fafc;
}
.budget-card-metrics b,
.budget-card-metrics small{display:block}
.budget-card-metrics small,
.budget-card-footer,
.mini-indicator{color:var(--muted);font-weight:800;font-size:11px}
.budget-card-footer{
  display:grid;
  gap:4px;
  overflow-wrap:anywhere;
}
.budget-card-indicators{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px;
}
.mini-indicator{
  border:1px solid var(--line);
  border-radius:999px;
  padding:5px 8px;
  background:#f8fafc;
}
.mini-indicator.on{
  color:#047857;
  background:#ecfdf5;
  border-color:#bbf7d0;
}

.budget-detail-shell{padding:18px;display:grid;gap:16px}
.detail-heading{grid-template-columns:auto minmax(0,1fr) auto}
.detail-metrics{grid-template-columns:repeat(4,minmax(0,1fr))}
.sticky-actions{
  position:sticky;
  top:88px;
  z-index:3;
  background:#fff;
  padding:10px;
  border:1px solid var(--line);
  border-radius:18px;
}
.budget-tabs{
  display:flex;
  gap:8px;
  overflow:auto;
  border-bottom:1px solid var(--line);
  padding-bottom:8px;
}
.budget-tabs button{
  border:1px solid var(--line);
  background:#fff;
  border-radius:999px;
  padding:8px 14px;
  font-weight:1000;
  color:#475569;
  cursor:pointer;
  white-space:nowrap;
}
.budget-tabs button.active{
  background:#0f62fe;
  color:#fff;
  border-color:#0f62fe;
}
.budget-tab-panel{display:grid;gap:16px}
.rich-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.rich-detail-grid div{border-radius:14px;padding:12px}
.origin-subtotals,
.import-summary-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
}
.origin-subtotals div,
.import-summary-grid div{
  border:1px solid var(--line);
  border-radius:16px;
  background:#f8fafc;
  padding:14px;
}
.origin-subtotals span,
.import-summary-grid span{display:block;color:var(--muted);font-weight:900;font-size:12px;text-transform:uppercase}
.origin-subtotals b,
.import-summary-grid b{display:block;margin-top:6px;font-size:18px}
.inline-head{padding:0;box-shadow:none;border:0;background:transparent}
.budget-items-list{display:grid;gap:12px}
.budget-item-card{
  border:1px solid var(--line);
  border-radius:18px;
  background:#fff;
  padding:14px;
  display:grid;
  gap:12px;
}
.item-main b,
.item-main span,
.item-main small{display:block}
.item-main b{color:#1d4ed8;font-size:13px}
.item-main span{font-weight:1000;margin:3px 0;overflow-wrap:anywhere}
.item-main small{color:var(--muted);font-weight:800}
.item-meta-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:8px;
}
.item-meta-grid > span{
  background:#f8fafc;
  border:1px solid var(--line);
  border-radius:12px;
  padding:9px;
  display:grid;
  gap:3px;
  min-width:0;
}
.item-meta-grid small{color:var(--muted);font-size:10px;font-weight:900;text-transform:uppercase}
.item-actions{justify-content:flex-end}
.floating-total{
  position:sticky;
  bottom:10px;
  z-index:2;
  display:flex;
  justify-content:space-between;
  gap:12px;
  border:1px solid #bfdbfe;
  background:#eff6ff;
  border-radius:16px;
  padding:12px 14px;
  box-shadow:0 14px 28px rgba(15,98,254,.12);
}
.modern-pdf-preview{max-height:none;min-height:0;border-radius:18px;background:#eef4ff;padding:12px}
.preview-note{background:#fff7ed;border:1px solid #fed7aa;border-radius:12px;padding:10px;color:#9a3412;font-weight:800}
.timeline-list{display:grid;gap:10px}
.timeline-item{border:1px solid var(--line);border-radius:14px;padding:12px;background:#f8fafc;display:flex;justify-content:space-between;gap:12px}
.timeline-item span{color:var(--muted);font-weight:800;text-align:right}

.form-step{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:12px;
  border:1px solid var(--line);
  border-radius:18px;
  padding:16px;
  margin-top:14px;
  background:#fff;
}
.step-badge{
  width:32px;
  height:32px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:#0f62fe;
  color:#fff;
  font-weight:1000;
}
.full-step-grid{grid-column:1 / -1}
.wide-field{grid-column:1 / -1}
.modal-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.split-actions{justify-content:space-between}
.action-cluster{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}
.item-mode-banner,.field-warnings span{
  border:1px solid #fed7aa;
  background:#fff7ed;
  color:#9a3412;
  border-radius:14px;
  padding:12px;
  display:block;
  margin:12px 0;
  font-weight:800;
}
.item-mode-banner span{display:block;color:#9a3412;font-weight:700;margin-top:4px}
.field-warnings{display:grid;gap:8px}

.stepper{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end;max-width:520px}
.stepper span{border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.12);border-radius:999px;padding:8px 10px;font-weight:900;font-size:12px;color:#dbeafe}
.stepper span.active{background:#fff;color:#0f62fe}
.import-workspace{display:grid;grid-template-columns:minmax(280px,.8fr) minmax(0,1.2fr);gap:20px;align-items:start}
.import-control-panel,.import-review-panel{padding:18px}
.modern-upload{margin-top:16px;min-height:220px}
.detected-card-list{display:grid;gap:12px}
.detected-card{border:1px solid var(--line);border-radius:18px;padding:14px;background:#fff}
.detected-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.compact-edit-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.compact-empty{margin-top:8px}

.report-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}
.chart-card,.ranking-card{padding:18px;min-width:0}
.bar-chart{display:grid;gap:12px}
.bar-row{display:grid;grid-template-columns:90px minmax(0,1fr) minmax(96px,auto);gap:10px;align-items:center}
.bar-row span,.bar-row b{font-size:12px;font-weight:900;color:#334155;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bar-track{height:14px;background:#e2e8f0;border-radius:999px;overflow:hidden}
.bar-track i,.ranking-row i{display:block;height:100%;background:linear-gradient(90deg,#0f62fe,#6d5dfc);border-radius:999px}
.status-chart{display:grid;gap:10px}
.status-segment{border:1px solid var(--line);border-radius:14px;padding:12px;background:#f8fafc;display:grid;grid-template-columns:1fr auto;gap:6px;align-items:center}
.status-segment div{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.status-segment small{grid-column:1/-1;color:var(--muted);font-weight:800}
.origin-chart{display:grid;grid-template-columns:170px minmax(0,1fr);gap:18px;align-items:center}
.chart-legend{display:grid;gap:10px}.chart-legend div{border:1px solid var(--line);border-radius:14px;padding:12px;background:#f8fafc}.chart-legend b,.chart-legend small{display:block;margin-top:4px}
.ranking-list{display:grid;gap:12px}
.ranking-row{display:grid;grid-template-columns:34px minmax(0,1fr) auto;gap:10px;align-items:center}
.rank{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:#eff6ff;color:#1d4ed8;font-weight:1000}
.ranking-row div{display:grid;gap:5px;min-width:0}.ranking-row b{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ranking-row small{color:var(--muted);font-weight:800}.ranking-row i{height:8px;background:linear-gradient(90deg,#22c55e,#0f62fe)}.ranking-row strong{font-size:12px;white-space:nowrap}

.rich-empty{display:grid;gap:8px;justify-items:start;text-align:left;align-content:center;min-height:96px}.rich-empty b{font-size:16px}.rich-empty span{color:var(--muted);font-weight:700}
.budget-card-list .rich-empty{min-height:124px}
.pagination-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-top:1px solid var(--line);color:var(--muted);font-size:12px;font-weight:900;flex-wrap:wrap}
.pagination-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end;align-items:center}
.page-size-control{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:12px;font-weight:900;white-space:nowrap}
.page-size-control select{height:34px;border:1px solid var(--line);border-radius:8px;background:#fff;color:#0f172a;padding:0 28px 0 10px;font-weight:900}
.pagination-bar .btn:disabled{opacity:.48;cursor:not-allowed}
.quote-honeypot{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;overflow:hidden!important;opacity:0!important;pointer-events:none!important}
.stock-warning-row{background:#fff7ed}
.stock-warning-cell{display:flex;flex-direction:column;gap:2px}
.stock-warning-cell small{color:#b45309;font-weight:900}
.stock-history-list{display:flex;flex-direction:column;gap:10px;max-height:420px;overflow:auto}
.stock-history-item{display:grid;grid-template-columns:1fr auto;gap:8px;padding:10px 0;border-bottom:1px solid var(--line)}
.stock-history-item b{display:block;color:var(--text)}
.stock-history-item span,.stock-history-item small{color:var(--muted)}
.skeleton-list{display:grid;gap:12px;padding:16px}.skeleton-line{height:18px;border-radius:999px;background:linear-gradient(90deg,#e2e8f0,#f8fafc,#e2e8f0);background-size:200% 100%;animation:skeleton 1.2s infinite linear}@keyframes skeleton{to{background-position:-200% 0}}
.toast.success{background:#047857}.toast.error{background:#b91c1c}.toast.warning{background:#b45309}.toast.info{background:#0f172a}
body.modal-open{overflow:hidden}.modal{max-height:min(88vh,900px);overflow:auto}.modal-backdrop.show{padding:16px}

@media (max-width:1180px){
  .dashboard-executive,.budget-workspace,.import-workspace{grid-template-columns:1fr}
  .budget-card-list{max-height:none}
  .budget-detail-pane{order:2}
  .filter-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .filter-actions{grid-column:1/-1}
}

@media (max-width:760px){
  .content{padding:16px;display:block}
  .content > *{margin-bottom:16px}
  .workspace-hero,.import-hero,.report-hero{grid-template-columns:1fr;padding:20px;border-radius:18px}
  .hero-metrics,.dashboard-action-grid,.origin-subtotals,.import-summary-grid,.report-grid{grid-template-columns:1fr}
  .dashboard-executive,.budget-workspace,.import-workspace{display:grid;grid-template-columns:1fr}
  .filter-grid,.compact-edit-grid,.rich-detail-grid,.detail-metrics,.item-meta-grid{grid-template-columns:1fr}
  .budget-tabs{padding-bottom:10px}
  .sticky-head,.sticky-actions{position:static}
  .budget-detail-shell,.budget-card-list,.import-control-panel,.import-review-panel,.chart-card,.ranking-card{padding:14px}
  .budget-actions-grid{grid-template-columns:1fr 1fr}
  .detail-heading,.compact-preview-top{grid-template-columns:1fr;text-align:left}
  .detail-heading .pill,.compact-preview-top .pill{justify-self:start}
  .origin-chart{grid-template-columns:1fr;justify-items:center}
  .bar-row{grid-template-columns:1fr;gap:6px}.bar-row b{text-align:left}
  .timeline-item{display:grid}.timeline-item span{text-align:left}
  .split-actions,.action-cluster{display:grid;grid-template-columns:1fr;width:100%}
  .split-actions .btn,.action-cluster .btn{width:100%}
}

@media (max-width:480px){
  .content{padding:12px}
  .stats,.compact-stats{grid-template-columns:1fr!important;gap:12px}
  .budget-actions-grid,.budget-card-metrics,.budget-metrics{grid-template-columns:1fr}
  .budget-hero h2,.dashboard-hero h2{font-size:22px}
  .budget-card,.budget-item-card,.detected-card{border-radius:16px;padding:12px}
  .modal-backdrop.show{align-items:flex-end;padding:0}.modal{width:100%;max-width:100%;max-height:92vh;border-radius:22px 22px 0 0}.modal-grid{grid-template-columns:1fr!important}
  .topbar{gap:8px}.search kbd{display:none}.search input{padding-right:12px}.user-name{display:none}
}

:root{
  --shadow:0 6px 18px rgba(15,23,42,.06);
  --radius:10px;
}

.content{
  padding:16px 18px 22px;
  gap:14px;
  grid-template-columns:minmax(0,1fr) 300px;
}

.topbar{
  height:62px;
  padding:0 18px;
  gap:12px;
}
.topbar h1{font-size:20px}.search input{height:38px}.avatar{width:36px;height:36px}.round{width:32px;height:32px}

.sidebar{padding:18px 14px}.menu{gap:5px}.menu-item{padding:10px 12px;font-size:14px}.brand h1{font-size:15px}

.stats{gap:12px}.stat-card{min-height:82px;padding:14px;gap:12px}.stat-icon{width:44px;height:44px;font-size:20px}.stat-card strong{font-size:22px}.stat-card p{font-size:13px;margin-bottom:3px}.up{font-size:11px}

.panel-head{padding:12px 14px;gap:10px}.panel-head h2{font-size:16px}.panel-head h2 span{padding:3px 8px;font-size:11px}.panel-actions{gap:6px}

.btn,
a.btn{
  min-height:34px;
  padding:0 12px;
  border-radius:7px;
  font-size:13px;
  font-weight:800;
  gap:6px;
}
.btn.primary{box-shadow:none}.btn:hover{transform:none}.btn.full{margin-top:6px}.compact-btn{min-height:30px;padding:0 10px;font-size:12px}
.icon-action{width:28px;height:28px;border-radius:7px}

.upload-zone{
  min-height:150px;
  grid-template-columns:110px minmax(0,1fr) 245px;
  gap:14px;
  padding:16px;
}
.pdf-icon{width:62px;height:82px;border-radius:8px}.pdf-icon:before{border-top-width:20px;border-left-width:20px}.pdf-icon span{padding:5px 7px;font-size:12px}.upload-text h2{font-size:18px;margin-bottom:6px}.upload-text p{font-size:13px;margin:4px 0}.upload-text small{font-size:11px;margin-top:7px}.ocr-box{padding:12px}.ocr-box h3{font-size:14px;margin-bottom:5px}.ocr-box p{font-size:12px;margin-bottom:8px}.ocr-box span{padding:5px 8px;font-size:11px}

th,td{padding:9px 10px;font-size:13px}.total-bar{padding:12px 14px}.total-bar strong{font-size:16px}.empty-state{padding:18px 12px}.manual{padding:14px}.manual h2{font-size:16px;margin-bottom:12px}.manual-grid{gap:8px}label{font-size:11px}input,select{height:34px;margin-top:5px;border-radius:7px;padding:0 10px}textarea{margin-top:5px;border-radius:7px;padding:10px}

.pdf-panel .pdf-preview{max-height:360px}.pdf-preview{padding:10px}.doc{padding:12px}.doc-head{padding-bottom:8px;margin-bottom:8px}.doc-meta{gap:6px}.mini th,.mini td{padding:6px;font-size:11px}.doc-total{padding:8px;font-size:14px}.summary .summary-numbers{gap:8px}.summary-numbers div{padding:10px}

.budget-hero,
.workspace-hero,
.import-hero,
.report-hero{
  background:#fff;
  color:var(--text);
  border:1px solid var(--line);
  border-radius:12px;
  padding:14px 16px;
  box-shadow:var(--shadow);
  grid-template-columns:minmax(0,1fr) auto;
  gap:12px;
}
.budget-hero:after{display:none}.budget-hero h2,.dashboard-hero h2{font-size:20px;margin:3px 0;letter-spacing:0}.budget-hero p,.dashboard-hero p{font-size:13px;color:var(--muted);font-weight:700}.eyebrow{font-size:10px;color:#2563eb}.budget-hero-actions,.hero-metrics{display:flex;flex-wrap:wrap;min-width:0;gap:8px;align-items:center;justify-content:flex-end}.budget-hero-actions > div{border:1px solid var(--line);background:#f8fafc;border-radius:10px;padding:8px 10px;min-width:92px}.budget-hero-actions b{font-size:16px}.budget-hero-actions span{font-size:10px;color:var(--muted)}.budget-hero-actions .btn{grid-column:auto;min-height:34px;border-radius:7px;background:var(--blue);color:#fff}

.filter-panel{border-radius:12px;padding:10px 12px;gap:8px}.filter-panel summary{font-size:13px}.filter-grid{gap:8px}.filter-panel input,.filter-panel select{min-height:34px;border-radius:7px}

.filter-grid{
  grid-template-columns:minmax(260px,2fr) minmax(210px,1fr) minmax(150px,.75fr) minmax(150px,.75fr) auto;
  align-items:end;
}

.filter-grid label{
  min-width:0;
}

.filter-grid select,
.filter-panel select,
.report-hero select{
  width:100%;
  min-width:190px;
}

.filter-grid input[type="date"]{
  min-width:150px;
}
.budget-workspace{gap:14px;grid-template-columns:minmax(360px,.82fr) minmax(0,1.18fr);align-items:start}.budget-list-pane{display:flex;flex-direction:column;min-height:0}.budget-list-pane .sticky-head{position:static;top:auto;z-index:auto}.budget-list-pane .panel-head,.budget-detail-shell{padding:12px}.budget-card-list{gap:8px;padding:10px;max-height:calc(100vh - 290px);min-height:160px;overflow-y:auto;scroll-padding-top:10px}.budget-card{padding:10px;border-radius:12px;gap:8px;scroll-margin-top:10px}.budget-card h3{font-size:14px}.budget-card p,.budget-card-footer{font-size:11px}.budget-card-metrics span{padding:8px}.budget-card-metrics b{font-size:13px}.mini-indicator{padding:3px 7px;font-size:11px}.budget-preview-top{padding:10px;border-radius:12px}.client-avatar{width:40px;height:40px;border-radius:12px}.budget-preview-top h2{font-size:16px}.budget-metrics{gap:7px}.budget-metrics div{padding:8px;border-radius:10px}.budget-metrics b{font-size:14px}.budget-tabs button{padding:6px 10px;font-size:12px}.rich-detail-grid,.origin-subtotals{gap:7px}.rich-detail-grid div,.origin-subtotals div{padding:9px;border-radius:10px}.budget-item-card{padding:10px;border-radius:12px;gap:8px}.item-meta-grid{gap:6px}.item-meta-grid > span{padding:7px;border-radius:9px}.floating-total{padding:9px 10px;border-radius:10px}

.modal-backdrop.show{padding:10px}.modal{max-width:760px;max-height:86vh;border-radius:14px;padding:18px}.compact-budget-modal{max-width:720px}.modal h2{font-size:19px;margin:0 0 10px}.modal-grid,.compact-form-grid{gap:9px}.modal-actions{gap:8px}.role-help,.compact-help{font-size:12px;padding:9px}.modal-title-row.compact-title-row{align-items:center;margin-bottom:8px}.item-mode-banner{padding:9px;margin:8px 0;border-radius:10px;font-size:12px}

.check-row,
.manual-mode,
.compact-check{
  display:inline-flex;
  align-items:center;
  justify-content:flex-start;
  gap:8px;
  min-height:34px;
  width:auto;
  max-width:100%;
  margin-top:5px;
  text-align:left;
}

.modal .check-row,
.modal .manual-mode,
.modal .compact-check{
  margin-top:5px;
}

input[type="checkbox"],
input[type="radio"],
.modal input[type="checkbox"],
.modal input[type="radio"],
.filter-grid input[type="checkbox"],
.filter-grid input[type="radio"]{
  width:16px;
  min-width:16px;
  max-width:16px;
  height:16px;
  min-height:16px;
  padding:0;
  margin:0;
  flex:0 0 16px;
  accent-color:var(--blue);
  box-shadow:none;
}

.check-row span,
.manual-mode span,
.compact-check span{
  line-height:1.25;
}

.chart-card,.ranking-card,.import-control-panel,.import-review-panel{padding:12px}.bar-row{gap:8px}.stepper span{padding:5px 8px;font-size:11px}.modern-upload{min-height:150px}

@media(max-width:1350px){
  .content{grid-template-columns:minmax(0,1fr) 280px}
  .upload-zone{grid-template-columns:90px minmax(0,1fr) 220px}
}

@media(max-width:1024px){
  .content{display:block;padding:14px}.content > *{margin-bottom:14px}.side-col{margin-top:14px}.upload-zone{grid-template-columns:90px minmax(0,1fr)}.ocr-box{grid-column:1/-1}.budget-workspace{grid-template-columns:1fr}.budget-card-list{max-height:none}.budget-hero{grid-template-columns:1fr}.budget-hero-actions{justify-content:flex-start}
}

@media(max-width:760px){
  .topbar{height:auto;min-height:58px;padding:8px 12px;flex-wrap:wrap}.topbar h1{font-size:18px}.search{order:3;flex-basis:100%;max-width:none;margin-left:0}.content{padding:12px}.stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.stat-card{padding:10px;min-height:72px}.stat-icon{width:36px;height:36px;font-size:17px}.stat-card strong{font-size:18px}.upload-zone{grid-template-columns:1fr;text-align:left;min-height:0}.upload-text{text-align:left}.pdf-icon{display:none}.panel-head{align-items:flex-start}.panel-actions{width:100%;justify-content:flex-start}.panel-actions .btn{width:auto}.manual-grid{grid-template-columns:1fr 1fr}.manual-grid label:first-of-type{grid-column:1/-1}.budget-actions-grid{grid-template-columns:1fr 1fr}.item-meta-grid,.rich-detail-grid,.origin-subtotals,.import-summary-grid,.report-grid{grid-template-columns:1fr}.modal{width:100%;max-width:100%;border-radius:16px 16px 0 0;padding:16px}.modal-backdrop.show{align-items:flex-end;padding:0}.modal-grid{grid-template-columns:1fr!important}.budget-card-indicators .btn{width:auto}.budget-hero h2,.dashboard-hero h2{font-size:18px}
}

@media(max-width:420px){
  .stats{grid-template-columns:1fr}.manual-grid,.budget-actions-grid{grid-template-columns:1fr}.btn,a.btn{min-height:36px}.user-name{display:none}th,td{font-size:12px}.budget-hero-actions > div{width:100%}
}

#dashboardManualForm.manual-grid{
  grid-template-columns:repeat(12,minmax(0,1fr));
  gap:10px;
  align-items:end;
}

#dashboardManualForm > label{
  min-width:0;
}

#dashboardManualForm > label:nth-of-type(1){grid-column:span 4}
#dashboardManualForm > label:nth-of-type(2){grid-column:span 2}
#dashboardManualForm > label:nth-of-type(3){grid-column:span 2}
#dashboardManualForm > label:nth-of-type(4){grid-column:span 2}
#dashboardManualForm > label:nth-of-type(5){grid-column:span 2}
#dashboardManualForm > label:nth-of-type(6){grid-column:span 2}
#dashboardManualForm > label:nth-of-type(7){grid-column:span 2}

#dashboardManualForm > .manual-mode{
  grid-column:span 6;
  min-height:34px;
  padding:8px 10px;
  border:1px solid #bfdbfe;
  background:#eff6ff;
  border-radius:10px;
}

#dashboardManualForm > .btn{
  grid-column:span 2;
  min-width:0;
  white-space:normal;
  line-height:1.15;
  padding:8px 10px;
}

#dashboardManualForm input,
#dashboardManualForm select{
  min-width:0;
}

@media(max-width:1180px){
  #dashboardManualForm.manual-grid{
    grid-template-columns:repeat(6,minmax(0,1fr));
  }

  #dashboardManualForm > label:nth-of-type(1){grid-column:span 3}
  #dashboardManualForm > label:nth-of-type(2),
  #dashboardManualForm > label:nth-of-type(3),
  #dashboardManualForm > label:nth-of-type(4),
  #dashboardManualForm > label:nth-of-type(5),
  #dashboardManualForm > label:nth-of-type(6),
  #dashboardManualForm > label:nth-of-type(7){grid-column:span 1}
  #dashboardManualForm > .manual-mode{grid-column:span 4}
  #dashboardManualForm > .btn{grid-column:span 2}
}

@media(max-width:760px){
  #dashboardManualForm.manual-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  #dashboardManualForm > label:nth-of-type(1),
  #dashboardManualForm > .manual-mode,
  #dashboardManualForm > .btn{
    grid-column:1 / -1;
  }

  #dashboardManualForm > label:nth-of-type(2),
  #dashboardManualForm > label:nth-of-type(3),
  #dashboardManualForm > label:nth-of-type(4),
  #dashboardManualForm > label:nth-of-type(5),
  #dashboardManualForm > label:nth-of-type(6),
  #dashboardManualForm > label:nth-of-type(7){
    grid-column:span 1;
  }
}

@media(max-width:460px){
  #dashboardManualForm.manual-grid{
    grid-template-columns:1fr;
  }

  #dashboardManualForm > label,
  #dashboardManualForm > .manual-mode,
  #dashboardManualForm > .btn{
    grid-column:1 / -1!important;
  }
}

@media(max-width:1280px){
  .content{
    grid-template-columns:minmax(0,1fr);
  }

  .side-col{
    display:grid;
    grid-template-columns:repeat(2,minmax(320px,1fr));
    gap:14px;
  }

  .pdf-panel,
  .summary{
    min-width:0;
  }
}

@media(max-width:820px){
  .side-col{
    grid-template-columns:minmax(0,1fr);
  }
}

.bar-row span,
.bar-row b,
.ranking-row b,
.ranking-row strong,
.btn,
a.btn,
.panel-actions .btn,
.filter-actions .btn,
.budget-actions-grid .btn,
.budget-tabs button,
.menu-item,
.user-name,
.stat-card p,
.stat-card strong{
  white-space:normal;
  overflow:visible;
  text-overflow:clip;
}

.filter-grid > label,
.filter-grid input,
.filter-grid select,
.filter-actions,
.report-grid > *,
.stats > *,
.compact-stats > *,
.panel-head > *,
.budget-card *,
.budget-detail-shell *,
.summary *,
.pdf-panel *,
.modal *{
  min-width:0;
}

.btn,
a.btn,
button,
.panel-actions .btn,
.filter-actions .btn,
.budget-actions-grid .btn,
.budget-card-indicators .btn,
.row-actions .btn,
.action-cluster .btn,
.upload-text .btn,
.empty-state .btn{
  overflow-wrap:normal;
  word-break:normal;
  hyphens:none;
}

.upload-text .btn,
.import-zone .btn,
.modern-upload .btn{
  min-width:150px;
  max-width:100%;
  padding-left:14px;
  padding-right:14px;
}

.upload-zone.import-zone,
.modern-upload{
  grid-template-columns:minmax(72px,auto) minmax(220px,1fr)!important;
  justify-items:center;
}

.upload-text{
  min-width:220px;
  max-width:100%;
}

.upload-text h2,
.upload-text h3,
.upload-text p,
.upload-text small{
  overflow-wrap:normal;
  word-break:normal;
}

@media(max-width:760px){
  .upload-zone.import-zone,
  .modern-upload{
    grid-template-columns:minmax(0,1fr)!important;
  }

  .upload-text{
    min-width:0;
  }

  .upload-text .btn,
  .import-zone .btn,
  .modern-upload .btn{
    width:100%;
  }
}

.btn,
a.btn,
button,
.panel-actions .btn,
.filter-actions .btn,
.budget-actions-grid .btn,
.budget-card-indicators .btn,
.row-actions .btn,
.action-cluster .btn,
.upload-text .btn,
.empty-state .btn{
  overflow-wrap:normal;
  word-break:normal;
  hyphens:none;
}

.upload-text .btn,
.import-zone .btn,
.modern-upload .btn{
  min-width:150px;
  max-width:100%;
  padding-left:14px;
  padding-right:14px;
}

.upload-zone.import-zone,
.modern-upload{
  grid-template-columns:minmax(72px,auto) minmax(220px,1fr)!important;
  justify-items:center;
}

.upload-text{
  min-width:220px;
  max-width:100%;
}

.upload-text h2,
.upload-text h3,
.upload-text p,
.upload-text small{
  overflow-wrap:normal;
  word-break:normal;
}

@media(max-width:760px){
  .upload-zone.import-zone,
  .modern-upload{
    grid-template-columns:minmax(0,1fr)!important;
  }

  .upload-text{
    min-width:0;
  }

  .upload-text .btn,
  .import-zone .btn,
  .modern-upload .btn{
    width:100%;
  }
}

.bar-row span,
.bar-row b,
.ranking-row b,
.ranking-row strong,
.btn,
a.btn,
.panel-actions .btn,
.filter-actions .btn,
.budget-actions-grid .btn,
.budget-tabs button,
.menu-item,
.user-name,
.stat-card p,
.stat-card strong{
  white-space:normal;
  overflow:visible;
  text-overflow:clip;
}

.filter-grid > label,
.filter-grid input,
.filter-grid select,
.filter-actions,
.report-grid > *,
.stats > *,
.compact-stats > *,
.panel-head > *,
.budget-card *,
.budget-detail-shell *,
.summary *,
.pdf-panel *,
.modal *{
  min-width:0;
}

.content,
.main-col,
.side-col,
.panel,
.stat-card,
.budget-hero,
.workspace-hero,
.import-hero,
.report-hero,
.filter-panel,
.filter-grid,
.report-grid,
.chart-card,
.ranking-card,
.budget-workspace,
.budget-list-pane,
.budget-detail-pane,
.budget-detail-shell,
.budget-card,
.budget-item-card,
.upload-zone,
.ocr-box,
.summary,
.pdf-panel,
.modal,
.modal-grid,
.settings-grid,
.dashboard-grid,
.manual-grid,
.budget-actions-grid,
.panel-head,
.panel-actions,
.total-bar,
.status-segment,
.ranking-row,
.bar-row{
  min-width:0;
}

.panel,
.stat-card,
.budget-card,
.budget-item-card,
.rich-detail-grid div,
.origin-subtotals div,
.import-summary-grid div,
.item-meta-grid > span,
.summary-numbers div,
.status-segment,
.timeline-item,
.filter-chip,
.mini-indicator,
.btn,
a.btn,
button,
label,
input,
select,
textarea,
h1,
h2,
h3,
p,
b,
strong,
small,
span{
  overflow-wrap:anywhere;
}

.btn,
a.btn,
.compact-btn,
.panel-actions .btn,
.filter-actions .btn,
.budget-actions-grid .btn,
.budget-card-indicators .btn,
.row-actions .btn,
.action-cluster .btn{
  white-space:normal;
  text-align:center;
  min-width:0;
  line-height:1.18;
}

.panel-head,
.total-bar,
.timeline-item,
.budget-card-top,
.detail-heading,
.compact-preview-top,
.modal-title-row,
.split-actions{
  flex-wrap:wrap;
}

.panel-head > div,
.panel-head h2,
.budget-card-top > div,
.detail-heading > div,
.compact-preview-top > div,
.workspace-hero > div,
.report-hero > div,
.import-hero > div{
  min-width:0;
}

.budget-hero h2,
.workspace-hero h2,
.import-hero h2,
.report-hero h2,
.dashboard-hero h2,
.panel-head h2,
.stat-card p,
.stat-card strong,
.budget-card h3,
.budget-card p,
.budget-card-footer,
.detail-box span,
.rich-detail-grid span,
.origin-subtotals b,
.origin-subtotals span,
.import-summary-grid b,
.import-summary-grid span,
.item-main span,
.item-meta-grid b,
.item-meta-grid small,
.summary b,
.summary span,
.summary small,
.doc,
.doc *{
  max-width:100%;
}

.filter-grid{
  grid-template-columns:minmax(220px,2fr) repeat(3,minmax(150px,1fr)) minmax(220px,auto);
}

.filter-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  justify-content:flex-end;
  min-width:0;
}

.filter-actions .btn,
.filter-actions a.btn{
  min-width:84px;
}

.hero-metrics{
  min-width:0;
  justify-content:flex-end;
}

.hero-metrics div,
.budget-hero-actions > div{
  min-width:104px;
  max-width:100%;
}

.bar-row{
  grid-template-columns:minmax(92px,.25fr) minmax(120px,1fr) minmax(92px,auto);
}

.bar-row span,
.bar-row b,
.ranking-row b,
.ranking-row strong{
  overflow:visible;
  text-overflow:clip;
  white-space:normal;
}

.ranking-row{
  grid-template-columns:34px minmax(0,1fr) minmax(78px,auto);
}

.status-segment{
  grid-template-columns:minmax(0,1fr) auto;
}

.chart-legend div,
.ranking-row div{
  min-width:0;
}

.topbar{
  min-width:0;
}

.topbar h1,
.user-name,
.search{
  min-width:0;
}

.search input{
  min-width:0;
  text-overflow:ellipsis;
}

@media(max-width:1500px){
  .report-grid{
    grid-template-columns:repeat(2,minmax(360px,1fr));
  }
}

@media(max-width:1180px){
  .workspace-hero,
  .import-hero,
  .report-hero,
  .budget-hero{
    grid-template-columns:1fr;
    align-items:start;
  }

  .hero-metrics,
  .budget-hero-actions{
    justify-content:flex-start;
    width:100%;
  }

  .filter-grid{
    grid-template-columns:repeat(2,minmax(220px,1fr));
  }

  .filter-actions{
    grid-column:1 / -1;
    justify-content:flex-start;
  }

  .report-grid{
    grid-template-columns:minmax(0,1fr);
  }
}

@media(max-width:760px){
  .online-alert{
    grid-template-columns:1fr;
  }

  .online-alert-actions,
  .online-alert-actions .btn{
    width:100%;
  }

  .panel-head,
  .total-bar,
  .timeline-item,
  .split-actions,
  .modal-title-row{
    display:grid;
    grid-template-columns:minmax(0,1fr);
  }

  .filter-grid,
  .stats,
  .compact-stats,
  .report-grid,
  .budget-workspace,
  .import-workspace,
  .dashboard-executive,
  .origin-subtotals,
  .import-summary-grid,
  .rich-detail-grid,
  .detail-metrics,
  .item-meta-grid{
    grid-template-columns:minmax(0,1fr)!important;
  }

  .filter-actions,
  .panel-actions,
  .budget-actions-grid,
  .action-cluster,
  .row-actions,
  .item-actions{
    display:grid;
    grid-template-columns:minmax(0,1fr);
    width:100%;
  }

  .filter-actions .btn,
  .filter-actions a.btn,
  .panel-actions .btn,
  .budget-actions-grid .btn,
  .row-actions .btn{
    width:100%;
  }

  .bar-row,
  .ranking-row,
  .status-segment{
    grid-template-columns:minmax(0,1fr);
  }

  .ranking-row .rank{
    justify-self:start;
  }

  .hero-metrics div,
  .budget-hero-actions > div{
    flex:1 1 150px;
  }
}

@media(max-width:480px){
  .content{
    padding:10px;
  }

  .budget-hero,
  .workspace-hero,
  .import-hero,
  .report-hero,
  .filter-panel,
  .panel,
  .stat-card{
    border-radius:10px;
  }

  .hero-metrics div,
  .budget-hero-actions > div{
    flex-basis:100%;
    width:100%;
  }

  .budget-tabs button{
    white-space:normal;
  }
}

@media(max-width:1500px){
  .content{
    grid-template-columns:minmax(0,1fr)!important;
  }

  .side-col{
    display:grid;
    grid-template-columns:repeat(2,minmax(320px,1fr));
    gap:14px;
    margin-top:0;
  }

  .pdf-panel,
  .summary{
    min-width:0;
  }
}

@media(max-width:820px){
  .side-col{
    grid-template-columns:minmax(0,1fr);
  }
}

.bar-row span,
.bar-row b,
.ranking-row b,
.ranking-row strong,
.btn,
a.btn,
.panel-actions .btn,
.filter-actions .btn,
.budget-actions-grid .btn,
.budget-tabs button,
.menu-item,
.user-name,
.stat-card p,
.stat-card strong{
  white-space:normal;
  overflow:visible;
  text-overflow:clip;
}

.filter-grid > label,
.filter-grid input,
.filter-grid select,
.filter-actions,
.report-grid > *,
.stats > *,
.compact-stats > *,
.panel-head > *,
.budget-card *,
.budget-detail-shell *,
.summary *,
.pdf-panel *,
.modal *{
  min-width:0;
}

.btn,
a.btn,
button,
.panel-actions .btn,
.filter-actions .btn,
.budget-actions-grid .btn,
.budget-card-indicators .btn,
.row-actions .btn,
.action-cluster .btn,
.upload-text .btn,
.empty-state .btn{
  overflow-wrap:normal;
  word-break:normal;
  hyphens:none;
}

.upload-text .btn,
.import-zone .btn,
.modern-upload .btn{
  min-width:150px;
  max-width:100%;
  padding-left:14px;
  padding-right:14px;
}

.upload-zone.import-zone,
.modern-upload{
  grid-template-columns:minmax(72px,auto) minmax(220px,1fr)!important;
  justify-items:center;
}

.upload-text{
  min-width:220px;
  max-width:100%;
}

.upload-text h2,
.upload-text h3,
.upload-text p,
.upload-text small{
  overflow-wrap:normal;
  word-break:normal;
}

@media(max-width:760px){
  .upload-zone.import-zone,
  .modern-upload{
    grid-template-columns:minmax(0,1fr)!important;
  }

  .upload-text{
    min-width:0;
  }

  .upload-text .btn,
  .import-zone .btn,
  .modern-upload .btn{
    width:100%;
  }
}


.config-status-panel,
.audit-panel{
  margin-top:16px;
}

.config-status-panel{
  padding-bottom:14px;
}

.compact-head{
  min-height:auto;
  padding-bottom:10px;
}

.compact-status-grid{
  grid-template-columns:repeat(4,minmax(150px,1fr));
  gap:8px;
}

.compact-status-grid div{
  min-height:auto;
  padding:10px 12px;
}

.compact-status-grid b{
  font-size:11px;
}

.compact-status-grid span{
  font-size:14px;
}

.status-editor-panel{
  display:grid;
  grid-template-columns:minmax(180px,1fr) minmax(180px,240px) auto;
  gap:10px;
  align-items:end;
  margin-top:10px;
  padding:12px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#f8fafc;
}

.status-editor-panel b{
  display:block;
  color:var(--text);
  font-size:13px;
  margin-bottom:3px;
}

.status-editor-panel span{
  color:var(--muted);
  font-size:12px;
  font-weight:700;
}

.status-editor-panel select{
  margin:0;
  min-width:0;
}

.status-editor-panel .btn{
  min-height:38px;
  white-space:nowrap;
}

.audit-panel .filters-grid.audit-filters-grid{
  grid-template-columns:1.1fr 1.1fr .9fr .9fr auto;
  gap:10px;
  align-items:end;
}

.audit-panel .filters-grid label{
  font-size:12px;
  gap:5px;
}

.audit-panel .filters-grid input,
.audit-panel .filters-grid select{
  min-height:38px;
  padding:8px 10px;
  font-size:13px;
}

.audit-panel .filter-actions{
  display:flex;
  gap:8px;
  justify-content:flex-end;
}

.audit-panel .btn{
  min-height:38px;
  padding:8px 14px;
}

.audit-panel table th,
.audit-panel table td{
  padding-top:11px;
  padding-bottom:11px;
}

@media (max-width:1100px){
  .compact-status-grid{
    grid-template-columns:repeat(2,minmax(180px,1fr));
  }
  .audit-panel .filters-grid.audit-filters-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media (max-width:640px){
  .compact-status-grid,
  .audit-panel .filters-grid.audit-filters-grid{
    grid-template-columns:1fr;
  }
  .audit-panel .filter-actions{
    justify-content:stretch;
  }
  .audit-panel .filter-actions .btn{
    flex:1;
  }
}


.sidebar-footer{
  padding:14px 12px 16px;
  border-top:1px solid rgba(255,255,255,.14);
  line-height:1.35;
}
.sidebar-footer strong{
  display:block;
  font-size:13px;
  font-weight:800;
  color:#fff;
  letter-spacing:.01em;
  margin-bottom:4px;
}
.sidebar-footer small{
  display:block;
  font-size:12px;
  color:rgba(255,255,255,.72);
  white-space:normal;
}
.config-status-panel,
.audit-panel{
  margin-top:14px;
}
.config-status-panel .panel-head,
.audit-panel .panel-head{
  min-height:42px;
  padding:14px 16px 10px;
}
.compact-status-grid,
.rich-detail-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:8px;
}
.compact-status-grid div,
.rich-detail-grid div{
  min-height:58px;
  padding:10px 12px;
  border-radius:10px;
}
.compact-status-grid b,
.rich-detail-grid b{
  font-size:11px;
  letter-spacing:.06em;
}
.compact-status-grid span,
.rich-detail-grid span{
  font-size:14px;
  line-height:1.25;
}
.audit-filters-grid{
  display:grid;
  grid-template-columns:minmax(180px,1.1fr) minmax(180px,1.1fr) minmax(145px,.8fr) minmax(145px,.8fr) auto;
  gap:10px;
  align-items:end;
  padding:0 16px 14px;
}
.audit-filters-grid label{
  display:flex;
  flex-direction:column;
  gap:5px;
  margin:0;
  font-size:12px;
  font-weight:700;
  color:#334155;
}
.audit-filters-grid input,
.audit-filters-grid select{
  width:100%;
  min-height:38px;
  padding:8px 10px;
  font-size:13px;
  border-radius:8px;
}
.audit-filters-grid .filter-actions{
  display:flex;
  gap:8px;
  justify-content:flex-end;
}
.audit-filters-grid .btn{
  min-height:38px;
  padding:8px 14px;
}
.audit-panel .table-wrap table th,
.audit-panel .table-wrap table td{
  padding-top:10px;
  padding-bottom:10px;
}
.danger-zone-panel{
  display:grid;
  grid-template-columns:minmax(0,1fr) 190px;
  gap:18px;
  align-items:center;
  border-color:#fecaca;
  background:#fff7f7;
  padding:16px;
}

.danger-zone-copy{
  min-width:0;
}

.danger-zone-copy h2{
  margin:4px 0 6px;
  font-size:22px;
  line-height:1.15;
}

.danger-zone-copy p{
  margin:0;
  color:#7f1d1d;
  font-weight:700;
  line-height:1.45;
  max-width:760px;
}

.btn.danger{
  background:#dc2626;
  color:#fff;
}

.btn.danger:hover{
  background:#b91c1c;
}

.danger-reset-btn{
  width:190px;
  min-height:42px;
  padding:0 18px;
  white-space:nowrap;
  justify-self:end;
}

.danger-confirm-box{
  border:1px solid #fecaca;
  background:#fff7f7;
  color:#7f1d1d;
  border-radius:10px;
  padding:12px 14px;
  margin:8px 0 14px;
}

.danger-confirm-box b,
.danger-confirm-box p{
  display:block;
  margin:0;
}

.danger-confirm-box p{
  margin-top:6px;
  line-height:1.45;
}

.reset-database-modal{
  max-width:760px;
}

.reset-database-modal .danger-confirm-box{
  margin:0 0 16px;
}

.reset-database-grid{
  align-items:start;
}

.reset-database-grid label{
  min-width:0;
}

.reset-database-actions{
  margin-top:18px;
}

@media(max-width:700px){
  .reset-database-modal .modal-grid{
    grid-template-columns:1fr;
  }

  .reset-database-actions{
    justify-content:stretch;
  }

  .reset-database-actions .btn{
    flex:1 1 100%;
  }
}
@media(max-width:1100px){
  .compact-status-grid,
  .rich-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .audit-filters-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .audit-filters-grid .filter-actions{justify-content:flex-start;}
  .danger-zone-panel{
    grid-template-columns:minmax(0,1fr) 170px;
  }
  .danger-reset-btn{
    width:170px;
  }
}
@media(max-width:640px){
  .compact-status-grid,
  .rich-detail-grid,
  .audit-filters-grid{grid-template-columns:1fr;}
  .danger-zone-panel{
    grid-template-columns:1fr;
    align-items:stretch;
  }
  .danger-zone-panel .btn,
  .danger-reset-btn{
    width:100%;
    justify-self:stretch;
  }
  .audit-filters-grid .filter-actions .btn{flex:1;}
}

/* Correção de comboboxes: evita select espremido/truncado nos filtros. */
.filter-panel .filter-grid{
  grid-template-columns:minmax(280px,2fr) minmax(220px,1.1fr) minmax(160px,.8fr) minmax(160px,.8fr) minmax(180px,auto)!important;
}

.filter-panel .filter-grid label,
.filter-panel .filter-grid input,
.filter-panel .filter-grid select{
  min-width:0;
}

.filter-panel .filter-grid select{
  min-width:200px;
}

.filter-panel .filter-grid input[type="date"]{
  min-width:155px;
}

@media(max-width:1180px){
  .filter-panel .filter-grid{
    grid-template-columns:repeat(2,minmax(220px,1fr))!important;
  }
}

@media(max-width:760px){
  .filter-panel .filter-grid{
    grid-template-columns:1fr!important;
  }

  .filter-panel .filter-grid select,
  .filter-panel .filter-grid input[type="date"]{
    min-width:0;
    width:100%;
  }
}

/* v3.9.56 - reforco visual dos comboboxes: texto sempre legivel e sem corte. */
select,
.filter-panel select,
.filter-grid select,
.modal select,
td select,
.import-destination select,
.audit-panel select,
.audit-filters-grid select{
  color:#0f172a!important;
  -webkit-text-fill-color:#0f172a;
  color-scheme:light;
  min-height:44px;
  line-height:1.25;
  padding:0 44px 0 14px!important;
  background-color:#fff!important;
  background-image:linear-gradient(45deg,transparent 50%,#0f172a 50%),linear-gradient(135deg,#0f172a 50%,transparent 50%)!important;
  background-position:calc(100% - 20px) 50%,calc(100% - 14px) 50%!important;
  background-size:6px 6px,6px 6px!important;
  background-repeat:no-repeat!important;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  opacity:1;
}

select option,
select optgroup{
  color:#0f172a;
  background:#fff;
  -webkit-text-fill-color:#0f172a;
}

select:disabled{
  color:#64748b!important;
  -webkit-text-fill-color:#64748b;
  background-color:#f1f5f9!important;
}

/* v3.9.57 - no celular o menu principal vira barra de atalhos inferior. */
@media(max-width:1024px){
  .app{
    display:block;
    min-height:100vh;
    padding-bottom:calc(82px + env(safe-area-inset-bottom));
  }

  .main{
    min-height:100vh;
  }

  .mobile-menu-btn{
    display:none!important;
  }

  .sidebar{
    display:flex!important;
    position:fixed!important;
    inset:auto 0 0 0!important;
    width:100%!important;
    height:auto!important;
    min-height:0!important;
    max-height:none!important;
    padding:8px 8px calc(8px + env(safe-area-inset-bottom))!important;
    z-index:80!important;
    transform:none!important;
    overflow:visible!important;
    background:rgba(255,255,255,.98)!important;
    color:#0f172a!important;
    border-top:1px solid rgba(148,163,184,.34);
    box-shadow:0 -14px 34px rgba(15,23,42,.16)!important;
  }

  .brand,
  .sidebar-footer,
  .sidebar-scrim{
    display:none!important;
  }

  .menu{
    width:100%;
    height:58px;
    margin:0!important;
    display:flex!important;
    flex-direction:row!important;
    align-items:stretch;
    gap:6px!important;
    overflow-x:auto;
    overflow-y:hidden;
    overscroll-behavior-x:contain;
    scrollbar-width:none;
    -webkit-overflow-scrolling:touch;
  }

  .menu::-webkit-scrollbar{
    display:none;
  }

  .menu-item{
    flex:0 0 74px;
    width:74px!important;
    min-width:74px;
    height:58px;
    padding:6px 5px!important;
    border-radius:12px!important;
    display:flex!important;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:3px!important;
    color:#475569!important;
    background:transparent!important;
    box-shadow:none!important;
    font-size:18px!important;
    line-height:1;
    text-align:center;
  }

  .menu-item span{
    display:block!important;
    width:100%;
    color:inherit;
    font-size:10px;
    line-height:1.08;
    font-weight:900;
    white-space:normal;
    overflow:hidden;
    text-overflow:ellipsis;
    display:-webkit-box!important;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
  }

  .menu-item:hover,
  .menu-item.active{
    color:#0f62fe!important;
    background:#eaf2ff!important;
    box-shadow:none!important;
  }

  body.menu-open{
    overflow:auto!important;
  }

  .toast{
    bottom:calc(94px + env(safe-area-inset-bottom));
  }
}

@media(max-width:420px){
  .menu-item{
    flex-basis:68px;
    width:68px!important;
    min-width:68px;
  }
}

/* v3.9.58 - fotos de produtos no cadastro e nos orcamentos. */

/* v3.10.02 - atualizacoes comercializadas, Pix e aplicador seguro. */
.update-banner{
  position:fixed;right:22px;bottom:22px;z-index:80;max-width:520px;background:#fff;border:1px solid #cfe2ff;
  box-shadow:0 18px 45px rgba(15,23,42,.18);border-radius:12px;padding:18px;display:grid;grid-template-columns:1fr auto;gap:16px;align-items:center
}
.update-banner b{display:block;font-size:18px;color:#0f172a;margin:2px 0 6px}.update-banner p{margin:0 0 8px;color:#475569;line-height:1.45}
.update-banner ul,.update-list{margin:8px 0 0;padding-left:18px;color:#334155}.update-banner-actions{display:grid;gap:8px;min-width:150px}
.update-modal h3{margin:18px 0 8px}.update-payment-area{margin-top:14px}.pix-box{display:grid;gap:12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:14px}
.pix-box textarea{width:100%;min-height:96px;box-sizing:border-box;resize:vertical}.pix-qr{width:190px;height:190px;object-fit:contain;justify-self:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:8px}
.update-approved{display:grid;gap:6px;background:#dcfce7;border:1px solid #86efac;color:#14532d;border-radius:10px;padding:14px}.update-approved b{font-size:16px}.inline-actions{justify-content:flex-start}
.update-clients-table{margin-top:16px}.update-admin-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:18px}.mini-log-list{display:grid;gap:8px}.mini-log-list div{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:10px}.mini-log-list b,.mini-log-list span{display:block}.mini-log-list span{color:#64748b;font-size:13px;margin-top:3px}
@media(max-width:780px){.update-banner{left:12px;right:12px;bottom:12px;grid-template-columns:1fr}.update-banner-actions{grid-template-columns:1fr 1fr}.update-admin-grid{grid-template-columns:1fr}}
.product-thumb{
  width:54px;
  height:54px;
  border-radius:10px;
  object-fit:cover;
  border:1px solid var(--line);
  background:#f8fafc;
  display:grid;
  place-items:center;
  color:#64748b;
  font-size:20px;
  overflow:hidden;
}

.product-thumb.empty{
  font-size:18px;
}

.product-photo-editor,
.item-product-preview{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:12px;
  align-items:center;
  border:1px solid var(--line);
  background:#f8fafc;
  border-radius:14px;
  padding:12px;
  margin-bottom:14px;
}

.product-photo-editor .product-thumb,
.item-product-preview .product-thumb{
  width:74px;
  height:74px;
  border-radius:12px;
  background:#fff;
}

.product-photo-editor b,
.product-photo-editor span,
.item-product-preview b,
.item-product-preview span{
  display:block;
}

.product-photo-editor b,
.item-product-preview b{
  color:#0f172a;
  font-size:14px;
  font-weight:1000;
}

.product-photo-editor span,
.item-product-preview span{
  margin:4px 0 10px;
  color:#64748b;
  font-size:12px;
  font-weight:800;
  line-height:1.35;
}

.file-btn{
  width:max-content;
  cursor:pointer;
}

.budget-item-card{
  grid-template-columns:auto minmax(0,1.2fr);
  align-items:start;
}

.budget-item-photo{
  grid-row:1 / span 3;
}

.budget-item-photo .product-thumb{
  width:82px;
  height:82px;
  border-radius:14px;
}

.mini .product-thumb{
  width:42px;
  height:42px;
  border-radius:8px;
  font-size:15px;
}

.budget-item-card .item-meta-grid,
.budget-item-card .item-actions{
  grid-column:2;
}

@media(max-width:640px){
  .status-editor-panel{
    grid-template-columns:1fr;
    align-items:stretch;
  }

  .status-editor-panel .btn{
    width:100%;
  }

  .budget-item-card{
    grid-template-columns:1fr;
  }

  .budget-item-photo,
  .budget-item-card .item-meta-grid,
  .budget-item-card .item-actions{
    grid-column:auto;
    grid-row:auto;
  }

  .budget-item-photo .product-thumb{
    width:100%;
    height:140px;
  }
}


/* Importador de produtos em Configuracoes - layout ajustado */
.product-import-panel{
  border:1px solid rgba(37,99,235,.20);
  background:linear-gradient(180deg,rgba(239,246,255,.88),#fff 78%);
  overflow:hidden;
}
.product-import-panel .panel-head{
  margin:0;
  padding:18px 20px 16px;
}
.product-import-panel .panel-head p{
  margin-top:12px;
  line-height:1.45;
}
.product-import-form{
  display:flex;
  flex-direction:column;
  gap:0;
}
.product-import-upload{
  display:grid;
  grid-template-columns:minmax(360px,1fr) minmax(120px,145px);
  gap:16px;
  align-items:end;
  padding:16px 20px 12px;
}
.product-import-upload label,
.product-import-fieldset label{
  min-width:0;
  margin:0;
}
.product-import-file,
.product-import-upload .compact-field{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.product-import-file{
  width:100%;
}
.file-picker-control{
  position:relative;
  display:flex;
  align-items:center;
  min-height:46px;
  width:100%;
  border:1px solid #d8e0ec;
  border-radius:12px;
  background:#fff;
  overflow:hidden;
  box-shadow:inset 0 1px 0 rgba(15,23,42,.03);
}
.file-picker-control:focus-within{
  border-color:#2563eb;
  box-shadow:0 0 0 3px rgba(37,99,235,.15);
}
.file-picker-control input[type="file"]{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  opacity:0;
  cursor:pointer;
  z-index:2;
}
.file-picker-button{
  flex:0 0 auto;
  align-self:stretch;
  display:flex;
  align-items:center;
  justify-content:center;
  min-width:150px;
  padding:0 18px;
  background:#0f62fe;
  color:#fff;
  border-right:1px solid rgba(15,98,254,.28);
  font-weight:900;
  white-space:nowrap;
}
.file-picker-name{
  min-width:0;
  flex:1 1 auto;
  padding:0 14px;
  color:#334155;
  font-weight:800;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.file-picker-control:hover .file-picker-button{
  background:#0b5bd3;
}
.product-import-upload .compact-field input{
  width:100%;
  height:46px;
  text-align:center;
  font-size:20px;
  line-height:46px;
  letter-spacing:.08em;
  border-radius:12px;
}
.product-import-fieldset{
  margin:0 20px;
  padding:14px;
  border:1px solid rgba(148,163,184,.28);
  border-radius:16px;
  background:rgba(255,255,255,.82);
}
.product-import-fieldset-title{
  margin:0 0 12px;
  color:#334155;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.product-import-grid{
  display:grid;
  grid-template-columns:minmax(100px,120px) minmax(260px,1fr) minmax(110px,140px) minmax(90px,110px) minmax(120px,145px);
  gap:12px;
  align-items:end;
}
.product-import-grid label{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.product-import-grid input{
  width:100%;
  min-width:0;
  height:42px;
  padding:0 12px;
  border-radius:12px;
  font-size:13px;
  font-weight:850;
  text-transform:uppercase;
  background:#fff;
}
.product-import-grid .field-code input,
.product-import-grid .field-unit input,
.product-import-grid .field-price input,
.product-import-grid .field-cost input{
  text-align:center;
}
.product-import-options{
  display:flex;
  gap:18px;
  flex-wrap:wrap;
  align-items:center;
  padding:14px 20px 0;
}
.product-import-options .check-row{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:30px;
  margin:0;
  padding:0;
}
.product-import-options .check-row input{
  flex:0 0 auto;
}
.product-import-actions{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  padding:12px 20px 18px;
}
.product-import-actions .btn{
  min-height:42px;
  padding:0 18px;
}
.product-import-actions small{
  flex:1 1 380px;
  display:block;
  padding:10px 12px;
  border:1px solid rgba(148,163,184,.20);
  border-radius:12px;
  background:#f8fafc;
  line-height:1.35;
}
.product-import-result{
  margin:0 20px 18px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(148,163,184,.35);
  background:#f8fafc;
  color:#0f172a;
  display:flex;
  flex-direction:column;
  gap:4px;
}
.product-import-result.success{
  border-color:rgba(22,163,74,.28);
  background:#f0fdf4;
  color:#14532d;
}
.product-import-result.error{
  border-color:rgba(220,38,38,.32);
  background:#fef2f2;
  color:#7f1d1d;
}
.product-import-result.loading{
  border-color:rgba(37,99,235,.28);
  background:#eff6ff;
  color:#1e3a8a;
}
.product-import-result ul{
  margin:6px 0 0 18px;
  padding:0;
}
.product-import-result[hidden]{
  display:none !important;
}
@media (max-width: 1180px){
  .product-import-upload{
    grid-template-columns:minmax(280px,1fr) minmax(110px,130px);
  }
  .product-import-grid{
    grid-template-columns:minmax(120px,.8fr) minmax(260px,1.4fr) minmax(130px,.8fr);
  }
  .product-import-grid .field-unit,
  .product-import-grid .field-cost{
    grid-column:auto;
  }
}
@media (max-width: 900px){
  .product-import-upload{
    grid-template-columns:1fr 120px;
  }
  .product-import-grid{
    grid-template-columns:1fr 1fr;
  }
  .product-import-grid .field-description{
    grid-column:1 / -1;
  }
}
@media (max-width: 720px){
  .product-import-panel .panel-head,
  .product-import-upload,
  .product-import-options,
  .product-import-actions{
    padding-left:14px;
    padding-right:14px;
  }
  .product-import-upload,
  .product-import-grid{
    grid-template-columns:1fr;
  }
  .product-import-fieldset,
  .product-import-result{
    margin-left:14px;
    margin-right:14px;
  }
  .product-import-grid .field-description{
    grid-column:auto;
  }
  .file-picker-control{
    flex-direction:column;
    align-items:stretch;
  }
  .file-picker-button{
    min-width:0;
    min-height:42px;
    border-right:0;
    border-bottom:1px solid #d8e0ec;
  }
  .file-picker-name{
    min-height:42px;
    display:flex;
    align-items:center;
  }
  .product-import-actions .btn{
    width:100%;
  }
}



.operational-status-grid{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:8px;
}

.operational-status-grid div{
  min-height:58px;
  padding:10px 12px;
  border-radius:10px;
}

.operational-status-grid b{
  font-size:11px;
  letter-spacing:.06em;
}

.operational-status-grid span{
  font-size:14px;
  line-height:1.25;
}

@media (max-width:1280px){
  .operational-status-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
}

@media (max-width:900px){
  .operational-status-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}

@media (max-width:640px){
  .operational-status-grid{grid-template-columns:1fr;}
}
