/* ─── VARIÁVEIS ─── */
:root {
    --acc: #c9a84c; --danger: #e05555; --warn: #e8923a; --info: #4ecdc4;
    --surf: #0d1225; --bg: #090d1a; --bg2: #111830; --bdr: #1e2d42;
    --txt: #e8eaf6; --txt2: #8b9bbf; --txt3: #4a5a7a;
}

body {
    background: var(--bg);
    font-family: 'DM Sans', system-ui, sans-serif;
    font-size: 14px;
}

::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--bdr); border-radius: 3px; }

/* ─── LOGO ─── */
.logo-area {
    display: flex; align-items: center; gap: 10px;
}
.logo-mk {
    width: 34px; height: 34px; border-radius: 9px; flex-shrink: 0;
    background: linear-gradient(135deg, #c9a84c, #9a7a2e);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.2rem; font-family: 'Cormorant Garamond', serif;
    font-style: italic; font-weight: 300; color: #050810;
    box-shadow: 0 2px 12px rgba(201,168,76,.3);
}
.logo-nome {
    font-family: 'Cormorant Garamond', serif;
    font-style: italic; font-weight: 300;
    font-size: 1.3rem; color: #c9a84c; letter-spacing: .1em;
}
.logo-sub {
    font-size: .75rem; color: rgba(201,168,76,.5); font-weight: 400;
}

/* ─── MUDAPPBAR OVERRIDE ─── */
.mud-appbar .search-field .mud-input-outlined .mud-notched-outline {
    border-color: rgba(201,168,76,.2) !important;
}
.mud-appbar .search-field .mud-input-outlined:hover .mud-notched-outline {
    border-color: rgba(201,168,76,.4) !important;
}

/* ─── SIDEBAR — overrides visuais do MudDrawer/MudNavMenu ─── */
.mud-nav-link {
    border-radius: 8px !important;
    margin: 1px 8px !important;
    color: var(--txt2) !important;
    font-size: .875rem !important;
    font-weight: 500 !important;
}
.mud-nav-link:hover {
    background: rgba(201,168,76,.08) !important;
    color: var(--acc) !important;
}
.mud-nav-link.active {
    background: rgba(201,168,76,.12) !important;
    color: var(--acc) !important;
    font-weight: 700 !important;
}
.mud-nav-link .mud-nav-link-text { color: inherit !important; }
.mud-nav-link .mud-icon-root { color: inherit !important; font-size: 1.1rem !important; }

.nav-section-label {
    font-size: .66rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: .6px; color: var(--txt3);
    padding: 10px 18px 4px;
}
.nav-divider {
    height: 1px; background: var(--bdr); margin: 6px 10px;
}
.nav-footer {
    margin-top: auto; padding: 12px;
    border-top: 1px solid var(--bdr);
    font-size: .69rem; color: var(--txt3); text-align: center;
    font-family: 'DM Mono', monospace; letter-spacing: .05em;
}

/* ─── BREADCRUMB ─── */
.bc { display: flex; align-items: center; gap: 6px; font-size: .78rem; color: var(--txt3); margin-bottom: 16px; }
.bc .sep { opacity: .5; }
.bc .cur { color: var(--txt); font-weight: 600; }
.bc .lnk { color: var(--acc); cursor: pointer; }
.bc .lnk:hover { text-decoration: underline; }

/* ─── PAGE HEADER ─── */
.ph { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 20px; gap: 16px; flex-wrap: wrap; }
.pt { font-size: 1.45rem; font-weight: 800; color: var(--txt); letter-spacing: -.4px; line-height: 1.1; }
.ps { font-size: .83rem; color: var(--txt2); margin-top: 4px; }

/* ─── KPI STRIP ─── */
.ks { display: grid; gap: 12px; margin-bottom: 20px; }
.k5 { grid-template-columns: repeat(5, 1fr); }
.k4 { grid-template-columns: repeat(4, 1fr); }
.k3 { grid-template-columns: repeat(3, 1fr); }

@media (max-width: 1200px) {
    .k5 { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 960px) {
    .k5 { grid-template-columns: repeat(2, 1fr); }
    .k4 { grid-template-columns: repeat(2, 1fr); }
    .k3 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .k5, .k4, .k3 { grid-template-columns: 1fr 1fr; }
}

.ki {
    background: var(--surf); border-radius: 10px; padding: 16px 18px;
    border-top: 3px solid var(--bdr); border: 1px solid var(--bdr);
    display: flex; flex-direction: column; gap: 4px;
}
.ki.kg { border-top-color: #2e7d32; }
.ki.kb { border-top-color: var(--info); }
.ki.ko { border-top-color: var(--warn); }
.ki.kr { border-top-color: var(--danger); }
.ki.kbr { border-top-color: var(--acc); }
.ki.kpk { border-top-color: #e91e63; }
.kl { font-size: .69rem; color: var(--txt3); font-weight: 700; text-transform: uppercase; letter-spacing: .4px; }
.kv { font-size: 1.65rem; font-weight: 800; color: var(--txt); line-height: 1.1; }
.kd { font-size: .73rem; color: var(--txt2); }
.kd.up { color: #4ecdc4; }
.kd.dn { color: var(--danger); }
.kd.nu { color: var(--txt3); }

/* ─── PILL FILTERS ─── */
.pf {
    display: inline-flex; align-items: center; padding: 4px 12px;
    border-radius: 20px; font-size: .74rem; font-weight: 600;
    border: 1px solid var(--bdr); cursor: pointer;
    background: var(--bg2); color: var(--txt2);
    transition: all .12s; font-family: inherit;
}
.pf:hover { background: rgba(201,168,76,.1); color: var(--acc); border-color: rgba(201,168,76,.2); }
.pf.on { background: var(--acc); color: #050810; border-color: var(--acc); }

/* ─── CELL PRIMARY + CELL META ─── */
.cp { font-weight: 700; cursor: pointer; }
.cm { color: var(--txt2); font-size: .79rem; margin-top: 1px; }

/* ─── ACTION CONTAINER + ROW BUTTONS ─── */
.ac { display: flex; gap: 4px; align-items: center; }
.rb {
    padding: 4px 10px; border-radius: 6px; font-size: .74rem; font-weight: 600;
    border: 1px solid var(--bdr); background: var(--bg2); color: var(--txt2);
    transition: background .12s; cursor: pointer; font-family: inherit; white-space: nowrap;
}
.rb:hover { background: var(--bdr); }
.rb.p { background: rgba(201,168,76,.12); color: var(--acc); border-color: rgba(201,168,76,.2); }
.rb.p:hover { background: rgba(201,168,76,.2); }
.rb.d { background: rgba(224,85,85,.12); color: var(--danger); border-color: rgba(224,85,85,.2); }
.rb.d:hover { background: rgba(224,85,85,.2); }

/* ─── CHIPS / BADGES ─── */
.chip { display: inline-flex; align-items: center; padding: 3px 9px; border-radius: 20px; font-size: .71rem; font-weight: 700; white-space: nowrap; }
.cg  { background: rgba(78,205,196,.12);  color: #4ecdc4; }
.cb  { background: rgba(78,140,205,.12);  color: #4e9ccd; }
.co  { background: rgba(232,146,58,.12);  color: #e8923a; }
.cr  { background: rgba(224,85,85,.12);   color: #e05555; }
.cpk { background: rgba(201,168,76,.12);  color: #c9a84c; }
.cy  { background: rgba(139,92,246,.12);  color: #7c3aed; }
.cgr { background: var(--bg2);            color: var(--txt3); }

/* ─── TIMELINE ─── */
.tl { padding: 16px; display: flex; flex-direction: column; }
.tle { display: flex; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--bdr); }
.tle:last-child { border-bottom: none; }
.tld { width: 32px; height: 32px; border-radius: 50%; background: rgba(201,168,76,.1); flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-size: .85rem; }
.tlt { font-size: .85rem; font-weight: 700; }
.tls { font-size: .78rem; color: var(--txt2); margin-top: 2px; }
.tlm { font-size: .71rem; color: var(--txt3); margin-top: 3px; }

/* ─── PROGRESS BAR (dias na fase) ─── */
.pm  { height: 3px; background: var(--bdr); border-radius: 2px; margin-top: 5px; overflow: hidden; width: 80px; }
.pmf { height: 100%; border-radius: 2px; }

/* ─── ALERT BANNER ─── */
.alert-banner {
    display: flex; align-items: center; justify-content: space-between;
    background: rgba(224,85,85,.08); border: 1px solid rgba(224,85,85,.2);
    border-radius: 10px; padding: 12px 18px; margin-bottom: 20px;
    cursor: pointer; transition: filter .15s;
}
.alert-banner:hover { filter: brightness(1.08); }

/* ─── CARD HEADER ─── */
.ch {
    display: flex; align-items: center; justify-content: space-between;
    padding: 12px 16px; border-bottom: 1px solid var(--bdr);
    background: var(--bg2); gap: 10px; flex-wrap: wrap;
}
.ct { font-size: .875rem; font-weight: 700; color: var(--txt); display: flex; align-items: center; gap: 7px; }

/* ─── UTIL ─── */
.cursor-pointer { cursor: pointer; }

/* ─── MAPA DA GRANJA — células de baia ─── */
:root {
    --baia-vaz: #1a2535;
    --baia-bai: #0d3320;
    --baia-med: #3d2a00;
    --baia-lot: #4a1500;
    --baia-scp: #3a0000;
}
.mgb-cell {
    width: 62px; height: 54px; border-radius: 6px; border: 1px solid var(--bdr);
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 2px; transition: filter .15s;
}
.mgb-cell:hover { filter: brightness(1.25); }
.mgb-num  { font-size: .72rem; font-weight: 700; color: var(--txt); }
.mgb-ocp  { font-size: .68rem; color: var(--txt2); }
.mgb-vaz  { background: var(--baia-vaz); }
.mgb-bai  { background: var(--baia-bai); }
.mgb-med  { background: var(--baia-med); }
.mgb-lot  { background: var(--baia-lot); }
.mgb-scp  { background: var(--baia-scp); }

/* ─── BUTTONS ─── */
.bg  { display: flex; gap: 8px; align-items: center; flex-shrink: 0; }
.btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 8px 16px; border-radius: 8px; font-size: .84rem; font-weight: 600;
    border: none; transition: all .15s; cursor: pointer;
    font-family: inherit; white-space: nowrap;
}
.btn:hover  { transform: translateY(-1px); }
.bp         { background: var(--acc); color: #050810; }
.bp:hover   { background: #e8d48a; }
.bo         { background: var(--surf); color: var(--txt2); border: 1.5px solid var(--bdr); }
.bo:hover   { background: var(--bg2); }
.bs         { padding: 6px 12px; font-size: .8rem; }

/* ─── GRIDS ─── */
.g2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 20px; }
.g3 { display: grid; grid-template-columns: 2fr 1fr; gap: 16px; margin-bottom: 20px; }
@media (max-width: 960px) {
    .g2, .g3 { grid-template-columns: 1fr; }
}

/* ─── CARD ─── */
.card {
    background: var(--surf); border-radius: 10px;
    border: 1px solid var(--bdr); overflow: hidden;
}

/* ─── FLUXO DE CAIXA (bar chart) ─── */
.bcw { padding: 14px 16px; display: flex; flex-direction: column; gap: 12px; }
.bcr { display: flex; align-items: center; gap: 10px; }
.bcl { font-size: .78rem; color: var(--txt2); width: 65px; flex-shrink: 0; }
.bct { flex: 1; background: var(--bdr); border-radius: 4px; height: 26px; overflow: hidden; }
.bcf {
    height: 100%; display: flex; align-items: center; padding-left: 8px;
    font-size: .74rem; font-weight: 700; color: #fff;
    border-radius: 4px; min-width: 40px; transition: width .4s;
}

/* ─── LISTA DE ALERTAS / VENCIMENTOS ─── */
.al  { display: flex; flex-direction: column; }
.ali {
    display: flex; align-items: flex-start; gap: 12px;
    padding: 12px 16px; border-bottom: 1px solid var(--bdr);
}
.ali:last-child { border-bottom: none; }
.ad  { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; margin-top: 5px; }
.ad.r { background: var(--danger); }
.ad.o { background: var(--warn); }
.ad.b { background: var(--info); }
.att { font-size: .84rem; color: var(--txt); }
.atm { font-size: .75rem; color: var(--txt3); margin-top: 2px; }
