:root{ --red:#cd1719; --bg:#0b0c0f; --panel:#14161b; --muted:#9aa3b2; --text:#e9edf1; --line:#252a33; }
*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:Inter,system-ui,Arial;background:var(--bg);color:var(--text)}
a{color:#f3b0b1;text-decoration:none}
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border:0;border-radius:10px;background:var(--red);color:#fff;cursor:pointer}
.btn.secondary{background:#2a2f39}.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--text)}
.input,.select{width:100%;padding:12px;border-radius:12px;border:1px solid var(--line);background:#0f1217;color:var(--text)}
.card{background:var(--panel);border-radius:16px;box-shadow:0 8px 24px rgba(0,0,0,.35);padding:16px; margin-bottom:10px}
.table{width:100%;border-collapse:collapse}.table th,.table td{border-top:1px solid var(--line);padding:10px 8px;text-align:left}
.badge{padding:4px 8px;border-radius:999px;background:#222f;display:inline-block}
.layout{display:grid;grid-template-columns:280px 1fr;min-height:100vh}
.sidebar{background:#0f1217;border-right:1px solid var(--line);display:flex;flex-direction:column}
.brand{display:flex;align-items:center;gap:10px;padding:16px 18px;border-bottom:1px solid var(--line)}
.brand .logo{width:28px;height:28px;border-radius:6px;background:linear-gradient(135deg,var(--red),#7a0c0e)}
.nav{display:flex;flex-direction:column;padding:8px}
.nav .group{margin-bottom:6px}
.nav .parent{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-radius:10px;color:var(--text);cursor:pointer}
.nav .parent:hover{background:rgba(205,23,25,.15)}
.nav .submenu{display:none;flex-direction:column;padding-left:10px}
.nav .submenu a{padding:8px 14px;border-radius:10px;color:var(--text)}
.nav .submenu a:hover{background:rgba(205,23,25,.1)}
.nav .submenu a:active{background:rgba(205,23,25,.1)}
.nav .submenu.show{display:flex}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-bottom:1px solid var(--line);background:#0f1217;position:sticky;top:0;z-index:5}
.content{padding:18px}
.kpis{display:grid;grid-template-columns:repeat(4,minmax(160px,1fr));gap:12px}
.kpi{background:var(--panel);border-left:4px solid var(--red);border-radius:12px;padding:14px}
.small{color:var(--muted);font-size:12px}
@media (max-width: 960px){ .layout{grid-template-columns:88px 1fr} .nav .parent span, .nav .submenu a{font-size:0}
 .nav .submenu{position:absolute;left:80px;top:0;background:#0f1217;border:1px solid var(--line)} }

 /* --- Sidebar safety + ellipsis --- */
.sidebar{overflow-x:hidden;}
.nav .parent{display:flex;align-items:center;gap:8px;}
.nav .parent span{
  flex:1 1 auto; min-width:0;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.nav .submenu{
  /* override the old "display:none" */
  display:flex !important; flex-direction:column;
  max-height:0; overflow:hidden;
  transition:max-height .30s ease; will-change:max-height;
}
.nav .submenu a{
  display:block;             /* take full width so ellipsis works */
  white-space:nowrap; text-overflow:ellipsis;
  position:relative; padding-left:28px; /* space for red dot */
}

/* red bullet before each submenu item */
.nav .submenu a::before{
  content:""; position:absolute; left:12px; top:50%; transform:translateY(-50%);
  width:8px; height:8px; border-radius:50%; background:var(--red); opacity:.9;
}

/* arrow rotates (you already have <b>▾</b> in the HTML) */
.nav .parent b{display:inline-block; transition:transform .25s ease;}
.nav .parent[aria-expanded="true"] b{transform:rotate(180deg);}

/* --- Content area never overflows horizontally --- */
.content{padding:18px; overflow-x:hidden;}
.content > *{min-width:0; max-width:100%;}
/* generic wrappers can wrap on smaller widths */
.content .toolbar, .content .filters, .content .controls, .content .row{
  display:flex; gap:10px; flex-wrap:wrap;
}

/* --- KPI grid falls back responsively --- */
@media (max-width:1320px){ .kpis{grid-template-columns:repeat(3,minmax(160px,1fr));} }
@media (max-width:1024px){ .kpis{grid-template-columns:repeat(2,minmax(160px,1fr));} }

/* keep full sidebar at tablet (undo the old font-size:0 rule) */
@media (max-width:960px){
  .layout{grid-template-columns:280px 1fr !important;}
  .nav .parent span, .nav .submenu a{font-size:inherit !important;}
  .nav .submenu{position:static !important; left:auto !important; top:auto !important; border:0 !important;}
}

/* --- Phone: off-canvas sidebar, hamburger visible --- */
@media (max-width:720px){
  .layout{grid-template-columns:1fr !important;}
  .content{padding:14px;}

  .sidebar{
    position:fixed; inset:0 auto 0 0;
    width:86%; max-width:320px;
    transform:translateX(-100%);
    transition:transform .30s ease;
    z-index:1000; box-shadow:8px 0 24px rgba(0,0,0,.35);
  }
  .sidebar.open{transform:translateX(0);}

  .backdrop{
    position:fixed; inset:0;
    background:rgba(0,0,0,.45);
    opacity:0; pointer-events:none;
    transition:opacity .20s ease; z-index:999;
  }
  .backdrop.show{opacity:1; pointer-events:auto;}

  /* show hamburger only on phones */
  .topbar [data-action="toggle-sidebar"]{display:inline-flex;}
}

/* hide hamburger on desktop/tablet */
@media (min-width:721px){
  .topbar [data-action="toggle-sidebar"]{display:none;}
}
.nav .submenu a.active{ background: rgba(205,23,25,.1); }

/* Optional but helpful: lightly mark the open parent when it has an active child */
.nav .parent.has-active{ background: rgba(205,23,25,.15); }
.nav .submenu a{
    white-space: normal !important;      /* remove single-line/ellipsis */
    overflow: visible !important;
    text-overflow: clip !important;
    overflow-wrap: anywhere;              /* break very long tokens */
    word-break: break-word;               /* fallback */
    line-height: 1.25;
    padding-top: 8px;
    padding-bottom: 8px;
  }