/* =====================================================================
   UrbanGap - Area Riservata - Stile (ispirato a Trend Monitor)
   Palette: #ffffff / #000000 / accent #e4092b
   Layout: sidebar nera fissa + main bianco
   Type:   Montserrat Semibold (titoli) + Manrope (testo)
   ===================================================================== */

@font-face {
  font-family: 'Montserrat';
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/Montserrat-SemiBold.woff2') format('woff2');
}
@font-face {
  font-family: 'Manrope';
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/Manrope-Regular.woff2') format('woff2');
}
@font-face {
  font-family: 'Manrope';
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/Manrope-SemiBold.woff2') format('woff2');
}

:root {
  --ug-white:       #ffffff;
  --ug-black:       #000000;
  --ug-accent:      #e4092b;
  --ug-accent-dark: #b30821;

  --ug-bg:          #f5f5f7;     /* main background */
  --ug-card:        #ffffff;     /* card background */
  --ug-border:      #e8e8ed;     /* sottile bordo */
  --ug-border-soft: #f0f0f3;

  --ug-text:        #0a0a0a;
  --ug-text-soft:   #5a5a64;
  --ug-text-muted:  #9097a3;

  --ug-sidebar-bg:    #0a0a0a;
  --ug-sidebar-text:  #cfcfd6;
  --ug-sidebar-mute:  #6b6b75;
  --ug-sidebar-active:#1a1a1f;

  --ug-pastel-violet: #efeafd;
  --ug-pastel-green:  #e6f6ec;
  --ug-pastel-yellow: #fef4dd;
  --ug-pastel-blue:   #e7f0fd;
  --ug-pastel-red:    #fde7eb;

  --ug-icon-violet:   #7c5cff;
  --ug-icon-green:    #2a8a3e;
  --ug-icon-yellow:   #c98800;
  --ug-icon-blue:     #2a6df4;

  --ug-success-bg:    #e6f6ec;
  --ug-success-text:  #1a6e30;
  --ug-danger-bg:     #fde7eb;
  --ug-danger-text:   #b30821;
  --ug-warn-bg:       #fef4dd;
  --ug-warn-text:     #8a5a00;

  --ug-radius:        10px;
  --ug-radius-sm:     6px;
  --ug-tr:            .18s ease;
  --ug-shadow-sm:     0 1px 2px rgba(15,15,20,.04);
  --ug-shadow-md:     0 4px 12px rgba(15,15,20,.06);

  --ug-sidebar-w:     240px;
}

* { box-sizing: border-box; }

html, body {
  background: var(--ug-bg);
  color: var(--ug-text);
  font-family: 'Manrope', system-ui, -apple-system, sans-serif;
  font-size: 14px;
  line-height: 1.55;
  margin: 0;
  -webkit-font-smoothing: antialiased;
}

h1,h2,h3,h4,h5,h6,
.ug-title {
  font-family: 'Montserrat', system-ui, sans-serif;
  font-weight: 600;
  letter-spacing: -.01em;
  color: var(--ug-text);
  margin: 0;
}

a { color: var(--ug-text); text-decoration: none; transition: color var(--ug-tr); }
a:hover { color: var(--ug-accent); }

/* =====================================================================
   LAYOUT - Sidebar + main
   ===================================================================== */
.ug-app {
  display: flex;
  min-height: 100vh;
}

.ug-sidebar {
  width: var(--ug-sidebar-w);
  background: var(--ug-sidebar-bg);
  color: var(--ug-sidebar-text);
  position: fixed;
  inset: 0 auto 0 0;
  display: flex;
  flex-direction: column;
  padding: 28px 16px 18px;
  z-index: 100;
}

.ug-sidebar-logo {
  padding: 0 8px 28px;
}
.ug-sidebar-logo img {
  display: block;
  height: 22px;
  width: auto;
}

.ug-sidebar-section {
  font-size: 10px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--ug-sidebar-mute);
  font-family: 'Manrope', sans-serif;
  font-weight: 600;
  padding: 18px 12px 8px;
}

.ug-sidebar-nav {
  list-style: none;
  padding: 0;
  margin: 0 0 4px 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.ug-sidebar-nav a {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  color: var(--ug-sidebar-text);
  border-radius: var(--ug-radius-sm);
  font-size: 14px;
  position: relative;
  transition: background var(--ug-tr), color var(--ug-tr);
}
.ug-sidebar-nav a:hover {
  background: var(--ug-sidebar-active);
  color: #fff;
}
.ug-sidebar-nav a.active {
  background: var(--ug-sidebar-active);
  color: #fff;
}
.ug-sidebar-nav a.active::before {
  content: "";
  position: absolute;
  left: -16px;
  top: 4px;
  bottom: 4px;
  width: 3px;
  background: var(--ug-accent);
  border-radius: 0 2px 2px 0;
}
.ug-sidebar-nav .ug-nav-icon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  opacity: .85;
}
.ug-sidebar-nav a.active .ug-nav-icon { opacity: 1; }

.ug-sidebar-version {
  margin-top: auto;
  padding: 12px;
  font-size: 11px;
  color: var(--ug-sidebar-mute);
}

/* Main area */
.ug-app-main {
  margin-left: var(--ug-sidebar-w);
  flex: 1;
  min-width: 0;
}

/* =====================================================================
   TOPBAR
   ===================================================================== */
.ug-topbar {
  background: var(--ug-card);
  border-bottom: 1px solid var(--ug-border);
  padding: 18px 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.ug-topbar-user {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
}
.ug-topbar-user-name { color: var(--ug-text); font-weight: 600; }
.ug-topbar-user-role {
  background: #2a6df4;
  color: #fff;
  font-size: 10px;
  letter-spacing: 1px;
  padding: 3px 8px;
  border-radius: 4px;
  font-weight: 600;
  text-transform: uppercase;
  font-family: 'Manrope', sans-serif;
}
.ug-topbar-user-role.role-super_admin { background: var(--ug-accent); }
.ug-topbar-user-role.role-admin       { background: #2a6df4; }
.ug-topbar-user-role.role-project_manager { background: #c98800; }
.ug-topbar-user-role.role-user        { background: var(--ug-text-muted); }

.ug-topbar-avatar {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--ug-bg);
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--ug-border);
  font-size: 14px;
}
.ug-topbar-logout {
  color: var(--ug-text-soft);
  font-size: 13px;
  padding: 6px 10px;
  border-radius: var(--ug-radius-sm);
}
.ug-topbar-logout:hover { color: var(--ug-accent); }

/* Page header (titolo h1 + breadcrumb) */
.ug-page-head {
  padding: 28px 32px 8px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}
.ug-page-title {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 24px;
  font-weight: 600;
}
.ug-page-title-icon {
  font-size: 22px;
  opacity: .9;
}
.ug-breadcrumb {
  margin-top: 4px;
  font-size: 13px;
  color: var(--ug-text-muted);
}
.ug-breadcrumb a { color: var(--ug-text-muted); }
.ug-breadcrumb a:hover { color: var(--ug-text); }
.ug-breadcrumb .sep { margin: 0 6px; }

.ug-page-actions { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }

/* Body */
.ug-page-body {
  padding: 16px 32px 40px;
}

/* =====================================================================
   BUTTONS
   ===================================================================== */
.ug-btn,
.btn-ug-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--ug-card);
  color: var(--ug-text);
  border: 1px solid var(--ug-border);
  padding: 9px 16px;
  font-family: 'Manrope', sans-serif;
  font-weight: 600;
  font-size: 13px;
  letter-spacing: .1px;
  border-radius: var(--ug-radius-sm);
  cursor: pointer;
  transition: all var(--ug-tr);
  text-decoration: none;
  line-height: 1.2;
}
.ug-btn:hover,
.btn-ug-primary:hover {
  border-color: var(--ug-text);
  color: var(--ug-text);
}

.ug-btn-accent {
  background: var(--ug-accent);
  border-color: var(--ug-accent);
  color: #fff !important;
}
.ug-btn-accent:hover {
  background: var(--ug-accent-dark);
  border-color: var(--ug-accent-dark);
  color: #fff !important;
}

.ug-btn-outline {
  background: transparent;
  color: var(--ug-accent);
  border-color: var(--ug-accent);
}
.ug-btn-outline:hover {
  background: var(--ug-pastel-red);
  color: var(--ug-accent-dark);
  border-color: var(--ug-accent-dark);
}

.ug-btn-ghost {
  background: transparent;
  border-color: transparent;
  color: var(--ug-text-soft);
}
.ug-btn-ghost:hover {
  background: var(--ug-bg);
  color: var(--ug-text);
  border-color: transparent;
}

.ug-btn-icon {
  width: 32px; height: 32px;
  padding: 0;
  justify-content: center;
}
.ug-btn-sm {
  padding: 6px 10px;
  font-size: 12px;
}

/* =====================================================================
   FORM
   ===================================================================== */
.form-control, .form-select {
  border: 1px solid var(--ug-border);
  border-radius: var(--ug-radius-sm);
  padding: 9px 12px;
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  background: var(--ug-card);
  color: var(--ug-text);
  transition: border-color var(--ug-tr), box-shadow var(--ug-tr);
  width: 100%;
}
.form-control:focus, .form-select:focus {
  border-color: var(--ug-text);
  box-shadow: 0 0 0 3px rgba(0,0,0,.06);
  outline: none;
}
.form-control-sm, .form-select-sm { padding: 6px 10px; font-size: 13px; }

.form-label {
  font-weight: 600;
  font-size: 13px;
  color: var(--ug-text);
  margin-bottom: 6px;
  display: block;
  letter-spacing: 0;
  text-transform: none;
}

/* =====================================================================
   LOGIN
   ===================================================================== */
.ug-login-wrap {
  min-height: 100vh;
  display: flex; align-items: center; justify-content: center;
  background: var(--ug-bg);
  padding: 20px;
}
.ug-login-card {
  background: var(--ug-card);
  padding: 44px 38px 36px;
  width: 100%; max-width: 420px;
  border-radius: var(--ug-radius);
  box-shadow: var(--ug-shadow-md);
  text-align: center;
}
.ug-login-icon {
  width: 64px; height: 64px;
  background: var(--ug-accent);
  border-radius: 16px;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 20px;
  color: #fff;
}
.ug-login-card h1 {
  font-size: 24px;
  margin-bottom: 4px;
  letter-spacing: -.01em;
}
.ug-login-subtitle {
  color: var(--ug-text-muted);
  font-size: 14px;
  margin-bottom: 28px;
}
.ug-login-card form { text-align: left; }

/* =====================================================================
   CARDS
   ===================================================================== */
.ug-card {
  background: var(--ug-card);
  border: 1px solid var(--ug-border);
  border-radius: var(--ug-radius);
  padding: 20px;
  margin-bottom: 16px;
  box-shadow: var(--ug-shadow-sm);
}

/* KPI card con icona pastello a sinistra */
.ug-kpi {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 18px 20px;
}
.ug-kpi-icon {
  width: 48px; height: 48px;
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.ug-kpi-icon svg { width: 24px; height: 24px; }
.ug-kpi-icon.violet { background: var(--ug-pastel-violet); color: var(--ug-icon-violet); }
.ug-kpi-icon.green  { background: var(--ug-pastel-green);  color: var(--ug-icon-green); }
.ug-kpi-icon.yellow { background: var(--ug-pastel-yellow); color: var(--ug-icon-yellow); }
.ug-kpi-icon.blue   { background: var(--ug-pastel-blue);   color: var(--ug-icon-blue); }
.ug-kpi-icon.red    { background: var(--ug-pastel-red);    color: var(--ug-accent); }

.ug-kpi-body { min-width: 0; flex: 1; }
.ug-kpi-value {
  font-family: 'Montserrat', sans-serif;
  font-size: 28px;
  font-weight: 600;
  line-height: 1.1;
  color: var(--ug-text);
  letter-spacing: -.02em;
}
.ug-kpi-label {
  color: var(--ug-text-muted);
  font-size: 13px;
  margin-top: 2px;
}

/* Vecchie classi mantenute per back-compat */
.ug-card-title {
  font-size: 12px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--ug-text-muted);
  margin-bottom: 12px;
  font-family: 'Manrope', sans-serif;
  font-weight: 600;
}
.ug-card-value {
  font-family: 'Montserrat', sans-serif;
  font-size: 26px;
  font-weight: 600;
  letter-spacing: -.02em;
}
.ug-card-value.text-accent { color: var(--ug-accent); }

.ug-stats {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 14px;
  margin-bottom: 22px;
}
@media (max-width: 1100px) { .ug-stats { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 600px)  { .ug-stats { grid-template-columns: 1fr; } }

/* Section header (titolo card + azione a destra) */
.ug-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--ug-border);
}
.ug-section-head h2,
.ug-section-head h3 {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 15px;
  font-weight: 600;
  margin: 0;
}
.ug-section-head .ug-section-icon { font-size: 16px; opacity: .85; }

.ug-card-flat { padding: 0; overflow: hidden; }
.ug-card-flat .ug-card-body { padding: 16px 20px; }

/* =====================================================================
   TABLES
   ===================================================================== */
.ug-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.ug-table thead th {
  background: transparent;
  color: var(--ug-text-muted);
  text-transform: uppercase;
  letter-spacing: 1px;
  font-size: 11px;
  padding: 12px 16px;
  font-family: 'Manrope', sans-serif;
  font-weight: 600;
  text-align: left;
  border-bottom: 1px solid var(--ug-border);
}
.ug-table tbody td {
  padding: 14px 16px;
  border-bottom: 1px solid var(--ug-border-soft);
  color: var(--ug-text);
  vertical-align: middle;
}
.ug-table tbody tr:last-child td { border-bottom: 0; }
.ug-table tbody tr:hover { background: var(--ug-bg); }
.ug-table .text-end { text-align: right; }

/* Card che contiene una tabella senza padding doppio */
.ug-table-wrap {
  background: var(--ug-card);
  border: 1px solid var(--ug-border);
  border-radius: var(--ug-radius);
  overflow: hidden;
  box-shadow: var(--ug-shadow-sm);
}

/* =====================================================================
   BADGE / PILL
   ===================================================================== */
.ug-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .5px;
  text-transform: uppercase;
  font-family: 'Manrope', sans-serif;
}
.ug-pill::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: currentColor;
}
.ug-pill.success { background: var(--ug-success-bg); color: var(--ug-success-text); }
.ug-pill.danger  { background: var(--ug-danger-bg);  color: var(--ug-danger-text); }
.ug-pill.warn    { background: var(--ug-warn-bg);    color: var(--ug-warn-text); }
.ug-pill.muted   { background: var(--ug-bg);         color: var(--ug-text-soft); }

/* badge senza dot (ruoli, categorie) */
.ug-tag {
  display: inline-block;
  padding: 3px 8px;
  border-radius: 4px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  background: var(--ug-bg);
  color: var(--ug-text-soft);
}
.ug-tag.dark { background: var(--ug-text); color: #fff; }
.ug-tag.accent { background: var(--ug-accent); color: #fff; }

/* mantengo .ug-vat-flag per back-compat */
.ug-vat-flag {
  display: inline-block;
  font-size: 10px; padding: 3px 8px;
  background: var(--ug-bg);
  color: var(--ug-text-soft);
  border-radius: 4px;
  text-transform: uppercase; letter-spacing: 1px;
  font-weight: 600;
}
.ug-vat-flag.yes { background: var(--ug-text); color: #fff; }

/* =====================================================================
   PROJECT CARDS (lista progetti / clienti)
   ===================================================================== */
.ug-grid-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(420px, 1fr));
  gap: 16px;
}
.ug-project-card {
  background: var(--ug-card);
  border: 1px solid var(--ug-border);
  border-radius: var(--ug-radius);
  padding: 0;
  box-shadow: var(--ug-shadow-sm);
  transition: box-shadow var(--ug-tr), border-color var(--ug-tr);
  display: flex;
  flex-direction: column;
}
.ug-project-card:hover { box-shadow: var(--ug-shadow-md); border-color: var(--ug-text-muted); }

.ug-project-head {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 18px;
  border-bottom: 1px solid var(--ug-border-soft);
}
.ug-project-icon {
  width: 36px; height: 36px;
  background: var(--ug-pastel-violet);
  color: var(--ug-icon-violet);
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.ug-project-titles { flex: 1; min-width: 0; }
.ug-project-name { font-weight: 600; font-size: 15px; color: var(--ug-text); }
.ug-project-meta { color: var(--ug-text-muted); font-size: 12px; margin-top: 2px; }

.ug-project-body { padding: 16px 18px; flex: 1; }
.ug-project-desc {
  color: var(--ug-text-soft);
  font-size: 13px;
  margin: 0 0 14px;
  line-height: 1.5;
}
.ug-project-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  font-size: 12px;
  color: var(--ug-text-soft);
}
.ug-project-stats span {
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.ug-project-stats .ic { color: var(--ug-icon-yellow); }
.ug-project-stats .ic.green { color: var(--ug-icon-green); }
.ug-project-stats .ic.blue  { color: var(--ug-icon-blue); }
.ug-project-stats .ic.violet{ color: var(--ug-icon-violet); }

.ug-project-foot {
  padding: 12px 18px;
  border-top: 1px solid var(--ug-border-soft);
  display: flex;
  gap: 8px;
  align-items: center;
}
.ug-project-foot .ug-btn-icon { margin-left: auto; color: var(--ug-text-muted); }
.ug-project-foot .ug-btn-icon:hover { color: var(--ug-accent); border-color: var(--ug-accent); }

/* =====================================================================
   KANBAN - Jira-inspired
   ===================================================================== */
.ug-kanban-filters {
  background: var(--ug-card);
  border: 1px solid var(--ug-border);
  border-radius: var(--ug-radius);
  padding: 14px 16px;
  margin-bottom: 16px;
}

.ug-kanban {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  align-items: start;
}
@media (max-width: 1100px) { .ug-kanban { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .ug-kanban { grid-template-columns: 1fr; } }

/* Colonna - sfondo grigio molto leggero, no bordo (Jira style) */
.ug-kanban-col {
  background: #f1f2f4;            /* grigio Jira */
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  min-height: 180px;
  max-height: calc(100vh - 280px);
  position: relative;
  overflow: hidden;
}

.ug-kanban-col-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px 8px;
  font-family: 'Manrope', sans-serif;
  font-weight: 600;
  letter-spacing: .6px;
  text-transform: uppercase;
  font-size: 11px;
  color: #6b7280;
}
.ug-kanban-col-title { display: inline-flex; align-items: center; gap: 6px; }

.ug-kanban-count {
  background: rgba(0,0,0,.06);
  color: #44546f;
  padding: 1px 8px;
  font-size: 11px;
  border-radius: 10px;
  font-weight: 600;
  min-width: 24px;
  text-align: center;
}

.ug-kanban-list {
  padding: 4px 8px 10px;
  flex: 1;
  overflow-y: auto;
  min-height: 60px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

/* TASK CARD - Jira style:
   sfondo bianco "puro" che però risalta sul grigio della colonna,
   shadow soft, NO border, hover con shadow più marcata */
.ug-task {
  background: #ffffff;
  padding: 10px 12px;
  border-radius: 6px;
  border: 0;
  box-shadow: 0 1px 1px rgba(9,30,66,.25), 0 0 1px rgba(9,30,66,.12);
  cursor: grab;
  transition: box-shadow var(--ug-tr), background var(--ug-tr);
  position: relative;
}
.ug-task:active { cursor: grabbing; }
.ug-task:hover {
  background: #f7f8f9;
  box-shadow: 0 4px 8px rgba(9,30,66,.16), 0 0 1px rgba(9,30,66,.18);
}
.ug-task-readonly { cursor: default; }
.ug-task-readonly:hover { background: #fff; box-shadow: 0 1px 1px rgba(9,30,66,.25), 0 0 1px rgba(9,30,66,.12); }

/* Striscia colore del task come tag laterale - sottile e non invadente */
.ug-task::before {
  content: "";
  position: absolute;
  left: 0; top: 8px; bottom: 8px;
  width: 3px;
  background: var(--task-color, var(--ug-accent));
  border-radius: 0 2px 2px 0;
}

.ug-task-title {
  font-weight: 500;
  font-size: 13px;
  line-height: 1.4;
  color: #172b4d;
  margin-bottom: 4px;
  padding-left: 4px;
}
.ug-task-desc {
  font-size: 12px;
  color: #44546f;
  line-height: 1.4;
  margin-bottom: 8px;
  padding-left: 4px;
}
.ug-task-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  font-size: 11px;
  color: #6b7280;
  padding-left: 4px;
  margin-top: 2px;
}
.ug-task-assignee {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  max-width: 60%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.ug-task-assignee-dot {
  width: 20px; height: 20px;
  border-radius: 50%;
  background: #dfe1e6;
  color: #44546f;
  font-size: 9px;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-transform: uppercase;
  flex-shrink: 0;
}
.ug-task-due {
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: #44546f;
}
.ug-task-due.overdue {
  color: var(--ug-accent);
  font-weight: 600;
}
.ug-task-due svg { width: 11px; height: 11px; }

.ug-kanban-col.drop-target {
  background: #d6e4ff;
}

.ug-placeholder {
  background: #d6e4ff !important;
  border-radius: 6px;
  height: 50px;
  box-shadow: none !important;
}
.ug-placeholder::before { display: none; }

/* Empty state colonna - molto discreto, no italic stridente */
.ug-kanban-empty {
  padding: 16px 14px;
  text-align: center;
  color: #97a0af;
  font-size: 12px;
}

/* =====================================================================
   ECONOMICS / MARGINI
   ===================================================================== */
.ug-margin-positive { color: var(--ug-success-text); font-weight: 600; }
.ug-margin-negative { color: var(--ug-accent); font-weight: 600; }

/* =====================================================================
   ATTACHMENTS
   ===================================================================== */
.ug-attachment-row {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 10px;
  background: var(--ug-bg);
  border-radius: var(--ug-radius-sm);
  margin-bottom: 6px;
  font-size: 13px;
}
.ug-attachment-row a { font-weight: 600; }

/* =====================================================================
   MODAL override
   ===================================================================== */
.modal-content { border-radius: var(--ug-radius); border: 1px solid var(--ug-border); box-shadow: 0 20px 60px rgba(0,0,0,.15); }
.modal-header { border-bottom: 1px solid var(--ug-border); padding: 18px 22px; }
.modal-header .modal-title { font-size: 16px; font-weight: 600; font-family: 'Montserrat', sans-serif; }
.modal-body { padding: 20px 22px; }
.modal-footer { border-top: 1px solid var(--ug-border); padding: 14px 22px; }

/* =====================================================================
   ALERT
   ===================================================================== */
.alert {
  border: 1px solid var(--ug-border);
  border-radius: var(--ug-radius-sm);
  padding: 10px 14px;
  font-size: 13px;
}
.alert-success { background: var(--ug-success-bg); border-color: #c6e8d0; color: var(--ug-success-text); }
.alert-danger  { background: var(--ug-danger-bg);  border-color: #f3c0c8; color: var(--ug-danger-text); }
.alert-warning { background: var(--ug-warn-bg);    border-color: #f0d99c; color: var(--ug-warn-text); }

/* =====================================================================
   PAGINATION
   ===================================================================== */
.ug-pagination {
  display: flex; gap: 6px; margin-top: 16px;
}
.ug-pagination a {
  width: 32px; height: 32px;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--ug-border);
  border-radius: var(--ug-radius-sm);
  font-size: 13px;
  background: var(--ug-card);
  color: var(--ug-text);
}
.ug-pagination a:hover { border-color: var(--ug-text); }
.ug-pagination a.active { background: var(--ug-accent); color: #fff; border-color: var(--ug-accent); }

/* =====================================================================
   UTILITIES
   ===================================================================== */
.text-muted { color: var(--ug-text-muted) !important; }
.ug-empty {
  padding: 60px 20px;
  text-align: center;
  color: var(--ug-text-muted);
  font-size: 14px;
}

/* Mobile sidebar */
@media (max-width: 900px) {
  :root { --ug-sidebar-w: 0px; }
  .ug-sidebar { transform: translateX(-100%); transition: transform .25s ease; box-shadow: 2px 0 20px rgba(0,0,0,.2); }
  .ug-sidebar.open { transform: translateX(0); }
  .ug-app-main { margin-left: 0; }
  .ug-mobile-toggle { display: inline-flex !important; }
}
.ug-mobile-toggle { display: none; }
