
/* InfraTrack v3.2.1 Phase 2 - Full Enterprise Layout Rebuild
   Global enterprise shell, sidebar, tables, forms, cards, modals, procurement and asset modules.
   Safe overlay only: no controller/route rewrites. */

:root{
  --itx-primary:#9b0000;
  --itx-primary-2:#7d0000;
  --itx-primary-soft:#fff1f2;
  --itx-text:#071327;
  --itx-sub:#475569;
  --itx-muted:#64748b;
  --itx-bg:#f3f6fb;
  --itx-panel:#ffffff;
  --itx-panel-2:#f8fbff;
  --itx-line:#dbe6f3;
  --itx-line-2:#e7eef7;
  --itx-success:#15803d;
  --itx-success-bg:#dcfce7;
  --itx-warning:#a16207;
  --itx-warning-bg:#fef3c7;
  --itx-danger:#b91c1c;
  --itx-danger-bg:#fee2e2;
  --itx-blue:#1d4ed8;
  --itx-blue-bg:#dbeafe;
  --itx-radius-sm:12px;
  --itx-radius:18px;
  --itx-radius-lg:24px;
  --itx-shadow:0 18px 45px rgba(15,23,42,.07);
  --itx-shadow-soft:0 10px 25px rgba(15,23,42,.055);
  --itx-font:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
}

/* Base shell */
html{scroll-behavior:smooth}
body{
  margin:0!important;
  background:
    radial-gradient(circle at 10% -10%, rgba(155,0,0,.055), transparent 28%),
    radial-gradient(circle at 88% 0%, rgba(29,78,216,.045), transparent 25%),
    var(--itx-bg)!important;
  color:var(--itx-text)!important;
  font-family:var(--itx-font)!important;
  -webkit-font-smoothing:antialiased!important;
  text-rendering:optimizeLegibility!important;
}
body *{box-sizing:border-box}
a{color:inherit}
img{max-width:100%}

/* Global app containers */
.app,.layout,.wrapper,.page,.main,.content,main,#app{
  font-family:var(--itx-font)!important;
}
.main,main,.content,.page-content,.app-main{
  background:transparent!important;
}
main,.main,.content{
  padding-top:18px!important;
}

/* Top bar and search */
.topbar,.app-topbar,.header,.page-top,.navbar{
  background:rgba(255,255,255,.88)!important;
  border-bottom:1px solid var(--itx-line)!important;
  backdrop-filter:blur(16px)!important;
  box-shadow:0 8px 24px rgba(15,23,42,.035)!important;
}
.search,.global-search,input[type="search"],.topbar input,.header input{
  min-height:42px!important;
  border-radius:999px!important;
  border:1px solid var(--itx-line)!important;
  background:#fbfdff!important;
}

/* Sidebar rebuild */
.sidebar,aside,.side-nav,.app-sidebar,.left-sidebar{
  background:rgba(255,255,255,.95)!important;
  border-right:1px solid var(--itx-line)!important;
  box-shadow:10px 0 35px rgba(15,23,42,.035)!important;
}
.sidebar a,aside a,.side-nav a,.app-sidebar a,.left-sidebar a,
.sidebar .nav-link,aside .nav-link,.menu a,.nav a{
  border-radius:14px!important;
  color:#334155!important;
  font-weight:750!important;
  transition:all .16s ease!important;
}
.sidebar a:hover,aside a:hover,.side-nav a:hover,.app-sidebar a:hover,.left-sidebar a:hover,
.sidebar .nav-link:hover,.menu a:hover,.nav a:hover{
  background:#f8fafc!important;
  color:var(--itx-primary)!important;
  transform:translateX(2px)!important;
}
.sidebar a.active,aside a.active,.side-nav a.active,.app-sidebar a.active,.left-sidebar a.active,
.sidebar .active,.menu .active,.nav .active{
  background:linear-gradient(90deg,var(--itx-primary-soft),#eef6ff)!important;
  color:var(--itx-primary)!important;
  border-left:4px solid var(--itx-primary)!important;
}
.sidebar h4,.sidebar .section-title,aside h4,aside .section-title,.menu-section{
  color:#94a3b8!important;
  font-size:11px!important;
  font-weight:900!important;
  letter-spacing:.09em!important;
  text-transform:uppercase!important;
}

/* Headings */
h1,h2,h3,h4,h5,.page-title,.section-title,.module-title{
  color:var(--itx-text)!important;
  letter-spacing:-.035em!important;
  font-weight:850!important;
}
h1,.page-title{font-size:clamp(24px,2vw,34px)!important}
h2{font-size:clamp(20px,1.7vw,28px)!important}
h3{font-size:clamp(17px,1.3vw,22px)!important}
p,.muted,.hint,.subtitle,small{color:var(--itx-muted)!important}
.eyebrow,.kicker,.module-eyebrow{
  color:var(--itx-primary)!important;
  font-size:12px!important;
  font-weight:900!important;
  text-transform:uppercase!important;
  letter-spacing:.12em!important;
}

/* Page headers */
.page-head,.module-head,.proc295-head,.proc296-head,.ops-head,.proc-enterprise-shell > .proc-head,
.proc-head,.view-head,.panel-head,.card-head{
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  margin:0 0 14px!important;
  padding:18px 4px!important;
  display:flex!important;
  justify-content:space-between!important;
  align-items:flex-start!important;
  gap:16px!important;
}

/* Cards and panels */
.card,.panel,.box,.module-card,.dashboard-card,.stat-card,.tile,.widget,
.proc-card,.proc295-card,.proc296-card,.ops-card,.pe-card,.amc-card,.asset-card,.license-card,
.table-wrap,.proc295-table-wrap,.proc296-table-wrap,.form-card,.detail-card,
.proc-enterprise-shell > section,.proc-enterprise-shell .card{
  background:rgba(255,255,255,.95)!important;
  border:1px solid var(--itx-line)!important;
  border-radius:var(--itx-radius-lg)!important;
  box-shadow:var(--itx-shadow-soft)!important;
}
.card,.panel,.box,.module-card,.dashboard-card,.stat-card,.tile,.widget,.form-card,.detail-card{
  padding:18px!important;
}
.card:hover,.module-card:hover,.tile:hover,.dashboard-card:hover,.asset-card:hover,.proc-card:hover{
  box-shadow:var(--itx-shadow)!important;
}

/* KPI cards */
.kpi,.stats-card,.stat-card,.dashboard-tile,.metric-card{
  min-height:118px!important;
  display:flex!important;
  flex-direction:column!important;
  justify-content:center!important;
  gap:8px!important;
}
.kpi .value,.stats-card .value,.stat-card .value,.dashboard-tile .value,.metric-card .value{
  font-size:clamp(28px,3vw,44px)!important;
  font-weight:900!important;
  letter-spacing:-.045em!important;
  color:var(--itx-text)!important;
}
.kpi .label,.stats-card .label,.stat-card .label,.dashboard-tile .label,.metric-card .label{
  color:var(--itx-muted)!important;
  font-weight:800!important;
}

/* Forms */
label,.form-label{
  color:#53657e!important;
  font-weight:850!important;
  font-size:12px!important;
  letter-spacing:.04em!important;
  text-transform:uppercase!important;
  margin-bottom:6px!important;
}
input,select,textarea{
  border:1px solid #cfdae9!important;
  border-radius:14px!important;
  min-height:42px!important;
  padding:10px 13px!important;
  background:#fff!important;
  color:var(--itx-text)!important;
  outline:0!important;
  box-shadow:none!important;
  transition:border-color .16s ease, box-shadow .16s ease, background .16s ease!important;
}
textarea{min-height:92px!important}
input:focus,select:focus,textarea:focus{
  border-color:#b8c8dc!important;
  box-shadow:0 0 0 4px rgba(155,0,0,.075)!important;
  background:#fff!important;
}
input[readonly],input:disabled,select:disabled,textarea:disabled{
  background:#f8fafc!important;
  color:#64748b!important;
}

/* Tables */
table,.table,.proc295-table,.proc296-table{
  width:100%!important;
  border-collapse:separate!important;
  border-spacing:0 10px!important;
}
thead th,.table-head th,.proc295-table th,.proc296-table th{
  background:#f8fbff!important;
  color:#53657e!important;
  font-size:12px!important;
  font-weight:900!important;
  letter-spacing:.04em!important;
  text-transform:uppercase!important;
  padding:13px 16px!important;
  border:0!important;
}
tbody tr{
  background:#fff!important;
  border-radius:18px!important;
  box-shadow:0 8px 22px rgba(15,23,42,.035)!important;
}
tbody td{
  padding:14px 16px!important;
  border-top:1px solid var(--itx-line-2)!important;
  border-bottom:1px solid var(--itx-line-2)!important;
  vertical-align:middle!important;
}
tbody td:first-child{
  border-left:1px solid var(--itx-line-2)!important;
  border-radius:18px 0 0 18px!important;
}
tbody td:last-child{
  border-right:1px solid var(--itx-line-2)!important;
  border-radius:0 18px 18px 0!important;
}

/* Button system */
a,button,input[type="submit"]{transition:all .16s ease!important}
.itx-ui-btn,
.btn,.button,.proc-btn,.proc295-btn,.proc296-btn,.pe-btn,.pe-mini,.mini-btn,
button,input[type="submit"],a.btn,a.button{
  min-height:38px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:8px!important;
  border-radius:12px!important;
  padding:8px 16px!important;
  font-size:13px!important;
  font-weight:850!important;
  line-height:1.1!important;
  text-decoration:none!important;
  white-space:nowrap!important;
  border:1px solid #d3deec!important;
  background:#fff!important;
  color:var(--itx-primary)!important;
  box-shadow:0 8px 20px rgba(15,23,42,.04)!important;
  cursor:pointer!important;
}
.itx-ui-btn:hover,.btn:hover,.button:hover,.proc-btn:hover,.proc295-btn:hover,.proc296-btn:hover,.pe-btn:hover,.pe-mini:hover,.mini-btn:hover,
button:hover,input[type="submit"]:hover,a.btn:hover,a.button:hover{
  transform:translateY(-1px)!important;
  background:#fff7f7!important;
  border-color:#c2cedf!important;
  color:var(--itx-primary-2)!important;
  box-shadow:0 14px 28px rgba(15,23,42,.09)!important;
}
.itx-primary,.primary,.btn-primary,.save,.submit,button[type="submit"],input[type="submit"]{
  background:linear-gradient(135deg,var(--itx-primary),var(--itx-primary-2))!important;
  color:#fff!important;
  border-color:transparent!important;
  box-shadow:0 12px 28px rgba(155,0,0,.18)!important;
}
.itx-primary:hover,.primary:hover,.btn-primary:hover,.save:hover,.submit:hover,button[type="submit"]:hover,input[type="submit"]:hover{
  background:linear-gradient(135deg,#850000,#680000)!important;
  color:#fff!important;
}
.itx-btn-open,.itx-btn-compare,.itx-btn-new,
a[href*="vendor-comparison"],a[href*="/compare"],a[href*="/requests/create"],a[href*="/create"],a[href*="/new"],
.proc296-btn.compare,.proc-btn-compare,.proc296-new{
  background:#fff!important;
  color:var(--itx-primary)!important;
  border:1px solid #d3deec!important;
  box-shadow:0 8px 20px rgba(15,23,42,.04)!important;
}
.itx-btn-open:hover,.itx-btn-compare:hover,.itx-btn-new:hover,
a[href*="vendor-comparison"]:hover,a[href*="/compare"]:hover,a[href*="/requests/create"]:hover,a[href*="/create"]:hover,a[href*="/new"]:hover,
.proc296-btn.compare:hover,.proc-btn-compare:hover,.proc296-new:hover{
  background:#fff7f7!important;
  border-color:#c8d4e4!important;
}
.itx-btn-edit,a[href*="/edit"]{
  background:#fff!important;
  color:var(--itx-primary)!important;
  border:1px solid #d3deec!important;
}
.itx-btn-delete,a[href*="/delete"],form[action*="/delete"] button,.danger,.btn-danger,.proc-btn-danger,.proc296-btn.danger,.mini-btn.danger{
  background:#fff!important;
  color:var(--itx-danger)!important;
  border:1px solid #fecaca!important;
  box-shadow:0 8px 20px rgba(185,28,28,.04)!important;
}
.itx-btn-delete:hover,a[href*="/delete"]:hover,form[action*="/delete"] button:hover,.danger:hover,.btn-danger:hover,.proc-btn-danger:hover,.proc296-btn.danger:hover,.mini-btn.danger:hover{
  background:#fff1f2!important;
  color:#991b1b!important;
  border-color:#fca5a5!important;
}

/* Buttons in cells and cards */
td:last-child,.action,.actions,.app-actions,.head-actions,.proc296-actions,.proc295-actions,.proc-actions{
  gap:10px!important;
}
td:last-child .itx-ui-btn,td:last-child .btn,td:last-child button,
.action .itx-ui-btn,.actions .itx-ui-btn,.app-actions .itx-ui-btn{
  margin:2px!important;
}
.head-actions,.proc296-actions,.proc295-actions,.proc-actions,.app-actions{
  display:flex!important;
  align-items:center!important;
  justify-content:flex-end!important;
  gap:10px!important;
  flex-wrap:wrap!important;
}

/* Quote cards */
.proc295-quote-grid,.quotation-grid,.submitted-quotations,.quote-grid,.quotes-grid{
  display:grid!important;
  grid-template-columns:repeat(auto-fit,minmax(215px,1fr))!important;
  gap:14px!important;
}
.quote-card,.proc295-quote-grid > div,.submitted-quotations > div,.quotation-grid > div,.quotes-grid > div{
  min-height:285px!important;
  display:flex!important;
  flex-direction:column!important;
  align-items:flex-start!important;
  border-radius:20px!important;
  padding:18px!important;
  background:#fff!important;
  border:1px solid var(--itx-line)!important;
  box-shadow:0 12px 28px rgba(15,23,42,.04)!important;
}
.quote-card > a[href*="/edit"],.quote-card > a[href*="/delete"],
.proc295-quote-grid > div > a[href*="/edit"],.proc295-quote-grid > div > a[href*="/delete"],
.submitted-quotations > div > a[href*="/edit"],.submitted-quotations > div > a[href*="/delete"]{
  align-self:center!important;
  min-width:90px!important;
  margin-left:auto!important;
  margin-right:auto!important;
}
.quote-card > a[href*="/edit"],.proc295-quote-grid > div > a[href*="/edit"],.submitted-quotations > div > a[href*="/edit"]{
  margin-top:auto!important;
}
.quote-card > a[href*="/delete"],.proc295-quote-grid > div > a[href*="/delete"],.submitted-quotations > div > a[href*="/delete"]{
  margin-top:7px!important;
}
.quote-card strong,.proc295-quote-grid strong,.submitted-quotations strong{
  color:var(--itx-primary)!important;
  font-size:24px!important;
  line-height:1.05!important;
}

/* Statuses */
.badge,.pill,.status,.proc296-pill,.proc-status-badge{
  border-radius:999px!important;
  padding:6px 11px!important;
  font-size:12px!important;
  font-weight:850!important;
  display:inline-flex!important;
  align-items:center!important;
  gap:4px!important;
}
.badge.success,.pill.success,.status.success,.proc296-pill.good,.complete{
  background:var(--itx-success-bg)!important;color:#166534!important;
}
.badge.danger,.pill.danger,.status.danger,.proc296-pill.bad,.incomplete{
  background:var(--itx-danger-bg)!important;color:#991b1b!important;
}
.badge.warning,.pill.warning,.status.warning,.draft{
  background:#f1f5f9!important;color:#334155!important;
}
.badge.info,.pill.info,.status.info{
  background:var(--itx-blue-bg)!important;color:#1e40af!important;
}

/* Delete modal */
.itx-modal-backdrop{
  position:fixed!important;
  inset:0!important;
  display:none;
  z-index:2147483000!important;
  background:rgba(15,23,42,.48)!important;
  backdrop-filter:blur(10px)!important;
  align-items:center!important;
  justify-content:center!important;
  padding:22px!important;
}
.itx-modal-backdrop.is-open{display:flex!important}
.itx-modal{
  width:min(460px,100%)!important;
  background:#fff!important;
  border:1px solid #e5eaf2!important;
  border-radius:24px!important;
  box-shadow:0 30px 90px rgba(15,23,42,.28)!important;
  padding:24px!important;
  color:var(--itx-text)!important;
  animation:itxPop .16s ease-out!important;
}
@keyframes itxPop{from{transform:translateY(12px) scale(.98);opacity:.4}to{transform:none;opacity:1}}
.itx-modal-icon{
  width:46px;height:46px;border-radius:16px;background:#fff1f2;color:var(--itx-danger);
  display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:900;margin-bottom:12px
}
.itx-modal h3{margin:0 0 8px!important;font-size:22px!important}
.itx-modal p{margin:0 0 20px!important;color:var(--itx-muted)!important;line-height:1.5!important}
.itx-modal-actions{display:flex!important;gap:10px!important;justify-content:flex-end!important}
.itx-modal-actions button{min-width:110px!important}

/* Layout helper classes injected by JS */
.itx-action-row{display:flex!important;align-items:center!important;justify-content:center!important;gap:10px!important;flex-wrap:wrap!important}
.itx-card-actions{margin-top:auto!important;display:flex!important;flex-direction:column!important;align-items:center!important;gap:8px!important;width:100%!important}

/* Mobile/tablet */
@media(max-width:1000px){
  .page-head,.module-head,.proc295-head,.proc296-head,.ops-head,.proc-head{
    flex-direction:column!important;
    align-items:flex-start!important;
  }
  .head-actions,.proc296-actions,.proc295-actions,.proc-actions,.app-actions{
    justify-content:flex-start!important;
  }
  .proc295-quote-grid,.quotation-grid,.submitted-quotations,.quote-grid,.quotes-grid{grid-template-columns:1fr!important}
  table,.table,.proc295-table,.proc296-table{font-size:13px!important}
}
@media(max-width:700px){
  body{font-size:14px!important}
  main,.main,.content{padding:14px!important}
  .card,.panel,.box,.module-card,.form-card,.detail-card{padding:14px!important;border-radius:18px!important}
  tbody td,thead th{padding:10px!important}
  .itx-ui-btn,.btn,.button,.proc-btn,.proc295-btn,.proc296-btn,.pe-btn,.pe-mini,.mini-btn,button,input[type="submit"]{
    min-height:40px!important;
    padding:9px 13px!important;
  }
}
