/* ===================================================================
   FPL — Demonstração Interativa Autónoma
   Design system: institucional moderno + layout de aplicação + dark mode
   Tipografia self-hosted: Fraunces (display) + IBM Plex Sans (body) + Plex Mono (código)
   =================================================================== */

/* ───── Tipografia self-hosted ───── */
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url('assets/fonts/fraunces-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url('assets/fonts/fraunces-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 300 700;
  font-display: swap;
  src: url('assets/fonts/plex-sans-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 300 700;
  font-display: swap;
  src: url('assets/fonts/plex-sans-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('assets/fonts/plex-mono-400-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('assets/fonts/plex-mono-400-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('assets/fonts/plex-mono-500-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('assets/fonts/plex-mono-500-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

:root{
  --gov:#0a3161;
  --gov-dark:#06203f;
  --gov-mid:#1d4d8c;
  --gov-light:#e8eef7;
  --accent:#b08020;
  --red:#c8102e;
  --green:#1a7f3c;
  --warning:#b86e00;
  --info:#0a5fa8;
  --ink:#0c1729;
  --ink-2:#3a4658;
  --ink-3:#5b6478;
  --ink-4:#9aa5b6;
  --line:#d9e0ea;
  --line-2:#eef0f3;
  --bg:#f1f4f8;
  --surface:#ffffff;
  --surface-2:#fafbfc;
  --serif:'Fraunces','Newsreader','Georgia',serif;
  --sans:'IBM Plex Sans',system-ui,-apple-system,sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,'SF Mono','Consolas',monospace;
  --r:4px; --r-lg:8px;
  --shadow-sm:0 1px 2px rgba(10,49,97,.05);
  --shadow:0 4px 16px rgba(10,49,97,.09);
  --shadow-lg:0 16px 48px rgba(10,49,97,.16);
}
:root[data-theme="dark"]{
  --gov-light:#1a2740;
  --ink:#e7eaf0; --ink-2:#c0c6d2; --ink-3:#9aa1ae; --ink-4:#6c7383;
  --line:#26303f; --line-2:#1c2331;
  --bg:#0e131c; --surface:#161c28; --surface-2:#1c2331;
  --shadow-sm:0 1px 2px rgba(0,0,0,.3);
  --shadow:0 4px 16px rgba(0,0,0,.4);
  --shadow-lg:0 16px 48px rgba(0,0,0,.55);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:var(--sans);font-size:14px;line-height:1.55;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;font-feature-settings:'ss01','cv11'}
h1,h2,h3,h4{font-family:var(--serif);font-weight:800;letter-spacing:-.02em;color:var(--ink);line-height:1.15}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
a{color:var(--gov);text-decoration:none}
input,select,textarea{font-family:inherit;font-size:14px;color:var(--ink)}
:focus-visible{outline:2px solid var(--gov);outline-offset:2px;border-radius:2px}
.mono{font-family:var(--mono)}
.muted{color:var(--ink-3)}
.small{font-size:.85rem}
.tiny{font-size:.75rem}
.eyebrow{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--gov)}

/* ===== Boot ===== */
.boot{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:var(--ink-3)}
.boot-crest{width:56px;height:56px;border-radius:50%;background:var(--gov);color:#fff;display:flex;align-items:center;justify-content:center}
.boot-crest svg{width:30px;height:30px}
.boot-spinner,.spinner{width:34px;height:34px;border:3px solid var(--line);border-top-color:var(--gov);border-radius:50%;animation:spin 1s linear infinite}
.spinner.sm{width:15px;height:15px;border-width:2px;display:inline-block;vertical-align:middle}
@keyframes spin{to{transform:rotate(360deg)}}

/* ===== Demo banner ===== */
.demo-banner{background:var(--accent);color:#2a1f00;text-align:center;font-size:.74rem;font-weight:600;letter-spacing:.04em;padding:5px 14px}
.demo-banner button{text-decoration:underline;font-weight:700}

/* ===== Login ===== */
.login{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(160deg,var(--gov) 0%,var(--gov-dark) 100%)}
.login-body{flex:1;display:flex;align-items:center;justify-content:center;padding:32px 20px}
.login-card{background:var(--surface);border-radius:var(--r-lg);max-width:760px;width:100%;box-shadow:var(--shadow-lg);overflow:hidden}
.login-head{padding:32px 40px 24px;border-bottom:1px solid var(--line)}
.login-head .crest{width:48px;height:48px;border-radius:50%;background:var(--gov);color:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.login-head .crest svg{width:26px;height:26px}
.login-head h1{font-size:1.5rem;margin-bottom:6px}
.login-head p{color:var(--ink-3);font-size:.92rem}
.login-roles{padding:24px 40px 32px}
.login-roles .lbl{font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-4);margin-bottom:14px}
.role-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.role-card{display:flex;align-items:center;gap:14px;padding:16px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--surface);text-align:left;transition:all .15s;cursor:pointer}
.role-card:hover{border-color:var(--gov);box-shadow:var(--shadow);transform:translateY(-1px)}
.role-card .avatar{width:42px;height:42px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.95rem;color:#fff}
.role-card .meta .nome{font-weight:600;font-size:.95rem}
.role-card .meta .papel{font-size:.78rem;color:var(--ink-3)}
.login-foot{padding:16px 40px;background:var(--surface-2);border-top:1px solid var(--line);font-size:.8rem;color:var(--ink-3)}

/* ===== Topbar ===== */
.topbar{position:sticky;top:0;z-index:50;background:var(--gov);color:#fff;display:flex;align-items:center;gap:20px;height:58px;padding:0 20px;border-bottom:3px solid var(--accent)}
.topbar .brand{display:flex;align-items:center;gap:11px;font-family:var(--serif);font-weight:600}
.topbar .brand .crest{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center}
.topbar .brand .crest svg{width:19px;height:19px}
.topbar .brand .bt{display:flex;flex-direction:column;line-height:1.15}
.topbar .brand .bt .t1{font-size:.62rem;opacity:.8;text-transform:uppercase;letter-spacing:.06em;font-family:var(--sans)}
.topbar .brand .bt .t2{font-size:.95rem}
.topbar nav{display:flex;gap:3px;margin-left:14px}
.topbar nav button{color:rgba(255,255,255,.82);padding:7px 13px;border-radius:var(--r);font-size:.86rem;font-weight:500}
.topbar nav button:hover{background:rgba(255,255,255,.1);color:#fff}
.topbar nav button.active{background:rgba(255,255,255,.16);color:#fff;font-weight:600}
.topbar .right{margin-left:auto;display:flex;align-items:center;gap:8px}
.icon-btn{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.85);position:relative}
.icon-btn:hover{background:rgba(255,255,255,.12);color:#fff}
.icon-btn svg{width:18px;height:18px}
.icon-btn .dot{position:absolute;top:6px;right:6px;width:8px;height:8px;border-radius:50%;background:var(--accent);border:2px solid var(--gov)}
.userchip{display:flex;align-items:center;gap:9px;padding:5px 9px 5px 5px;background:rgba(255,255,255,.1);border-radius:20px;cursor:pointer}
.userchip:hover{background:rgba(255,255,255,.16)}
.userchip .avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.74rem;color:#fff}
.userchip .um{display:flex;flex-direction:column;line-height:1.15}
.userchip .um .n{font-size:.78rem;font-weight:600}
.userchip .um .r{font-size:.64rem;opacity:.8;text-transform:uppercase;letter-spacing:.03em}

/* ===== Shell ===== */
.shell{display:flex;min-height:calc(100vh - 58px - 27px)}
.sidebar{width:226px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--line);padding:18px 0;overflow-y:auto}
.side-sec{margin-bottom:20px}
.side-sec .st{font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-4);padding:0 18px;margin-bottom:6px}
.side-link{display:flex;align-items:center;gap:11px;padding:9px 18px;font-size:.88rem;color:var(--ink-2);border-left:3px solid transparent;cursor:pointer;width:100%;text-align:left}
.side-link:hover{background:var(--surface-2);color:var(--ink)}
.side-link.active{background:var(--gov-light);color:var(--gov);border-left-color:var(--gov);font-weight:600}
.side-link svg{width:17px;height:17px;flex-shrink:0;opacity:.8}
.side-link .count{margin-left:auto;background:var(--gov);color:#fff;font-size:.66rem;font-weight:700;padding:1px 7px;border-radius:9px;font-family:var(--mono)}
.side-link.active .count{background:var(--gov)}
.main{flex:1;min-width:0;padding:26px 32px;overflow-x:hidden}
.footer{background:var(--surface);border-top:1px solid var(--line);text-align:center;padding:7px;font-size:.7rem;color:var(--ink-4)}

/* ===== Page head ===== */
.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:22px;flex-wrap:wrap}
.page-head .pt{font-size:1.7rem;font-family:var(--serif);font-weight:600;color:var(--gov-dark)}
:root[data-theme="dark"] .page-head .pt{color:var(--ink)}
.page-head .ps{font-size:.9rem;color:var(--ink-3);margin-top:3px}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;gap:7px;padding:8px 15px;font-size:.86rem;font-weight:500;border-radius:var(--r);border:1px solid var(--line);background:var(--surface);color:var(--ink);transition:all .14s}
.btn:hover{background:var(--surface-2);border-color:var(--ink-4)}
.btn:disabled{opacity:.45;cursor:not-allowed}
.btn svg{width:15px;height:15px}
.btn.primary{background:var(--gov);color:#fff;border-color:var(--gov)}
.btn.primary:hover{background:var(--gov-dark);border-color:var(--gov-dark)}
.btn.accent{background:var(--accent);color:#2a1f00;border-color:var(--accent)}
.btn.accent:hover{filter:brightness(.95)}
.btn.success{background:var(--green);color:#fff;border-color:var(--green)}
.btn.danger{color:var(--red);border-color:#e8b5bb}
.btn.danger:hover{background:#fdf2f3}
.btn.ghost{border-color:transparent;color:var(--ink-3)}
.btn.ghost:hover{background:var(--surface-2);color:var(--ink)}
.btn.sm{padding:5px 10px;font-size:.78rem}
.btn.block{width:100%;justify-content:center;padding:11px}

/* ===== KPI ===== */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 18px;box-shadow:var(--shadow-sm)}
.kpi .l{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);margin-bottom:6px}
.kpi .v{font-family:var(--serif);font-size:1.9rem;font-weight:600;color:var(--gov-dark);line-height:1}
:root[data-theme="dark"] .kpi .v{color:var(--ink)}
.kpi .d{font-size:.76rem;color:var(--ink-3);margin-top:5px}
.kpi .d.up{color:var(--green)} .kpi .d.down{color:var(--red)}

/* ===== Card ===== */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden;margin-bottom:18px}
.card-h{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;border-bottom:1px solid var(--line);background:var(--surface-2)}
.card-h h3{font-family:var(--sans);font-size:.95rem;font-weight:600}
.card-h .sub{font-size:.78rem;color:var(--ink-3);margin-top:1px}
.card-b{padding:16px 18px}
.card-empty{padding:48px 24px;text-align:center;color:var(--ink-4);font-size:.9rem}
.grid-2{display:grid;grid-template-columns:1.7fr 1fr;gap:18px}

/* ===== Table ===== */
.tbl{width:100%;border-collapse:collapse;font-size:.86rem}
.tbl th{text-align:left;padding:9px 13px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-3);background:var(--surface-2);border-bottom:1px solid var(--line)}
.tbl td{padding:12px 13px;border-bottom:1px solid var(--line-2);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tr.clickable:hover td{background:var(--surface-2);cursor:pointer}
.tbl .cel-num{font-family:var(--mono);font-size:.78rem;color:var(--ink-3)}
.tbl .cel-t{font-weight:500;max-width:380px}
.tbl .cel-t .s{font-size:.74rem;color:var(--ink-4);margin-top:2px;font-weight:400}
.txt-r{text-align:right}

/* ===== Badges / tags ===== */
.badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:11px;font-size:.7rem;font-weight:600;white-space:nowrap;border:1px solid}
.badge::before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor;margin-right:5px}
.badge.criado{color:#5b6478;background:#eef0f4;border-color:#d6dae1}
.badge.elaboracao{color:#8a5a00;background:#fff7e0;border-color:#f0d997}
.badge.consulta{color:#1e3a8a;background:#e0e9fb;border-color:#b9caf0}
.badge.rse{color:#5a23a8;background:#f0e2ff;border-color:#d6bcf6}
.badge.cm{color:#8a1c1c;background:#ffe2e2;border-color:#f0b8b8}
.badge.aprovado{color:#0a4520;background:#d8f5e3;border-color:#a8d6b8}
.badge.publicado{color:#fff;background:var(--gov);border-color:var(--gov)}
.badge.publicado::before{background:var(--accent)}
.badge.revisao{color:#8a3a00;background:#ffe5d2;border-color:#f0bf95}
.badge.arquivado{color:#5b6478;background:#eef0f4;border-color:#d6dae1}
.tag{display:inline-block;padding:2px 7px;font-family:var(--mono);font-size:.7rem;font-weight:600;border-radius:3px;background:var(--surface-2);color:var(--ink-2);border:1px solid var(--line)}
.tag.t-DL{background:#e8eef7;color:var(--gov);border-color:#c4d2e8}
.tag.t-PL{background:#fce7f3;color:#9d174d;border-color:#f4b8d6}
.tag.t-RCM{background:#dcfce7;color:#166534;border-color:#9ae0b4}
.tag.t-DR{background:#fef3c7;color:#854d0e;border-color:#f0d997}
.tag.t-DESPACHO{background:#ede9fe;color:#5b21b6;border-color:#cdbef2}

/* ===== Filters ===== */
.filters{display:flex;flex-wrap:wrap;gap:10px;align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:11px 14px;margin-bottom:16px;box-shadow:var(--shadow-sm)}
.filters input[type=text],.filters select{padding:6px 10px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface)}
.filters input[type=text]{min-width:230px}
.filters .sep{flex:1}

/* ===== FPL detalhe ===== */
.fpl-head{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px 26px;margin-bottom:16px;box-shadow:var(--shadow-sm)}
.fpl-head .crumb{font-size:.78rem;color:var(--ink-3);margin-bottom:8px}
.fpl-head .crumb button{color:var(--ink-3);text-decoration:underline}
.fpl-head h2{font-size:1.32rem;line-height:1.4;margin:8px 0 10px}
.fpl-head .meta{display:flex;flex-wrap:wrap;gap:22px;font-size:.82rem;margin-top:14px;padding-top:14px;border-top:1px solid var(--line-2)}
.fpl-head .meta .mi{display:flex;flex-direction:column;gap:2px}
.fpl-head .meta .mi .l{font-size:.66rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-4)}
.fpl-head .meta .mi .v{color:var(--ink-2);font-weight:500}
.fpl-head .actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}

/* ===== Pipeline marcos ===== */
.pipeline{display:flex;gap:5px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:14px;margin-bottom:16px;box-shadow:var(--shadow-sm)}
.pl-step{flex:1;text-align:center;padding:10px 6px;border-radius:var(--r);background:var(--surface-2);border:1px solid var(--line);position:relative}
.pl-step .m{font-family:var(--mono);font-weight:700;font-size:.82rem;color:var(--ink-4)}
.pl-step .n{font-size:.66rem;color:var(--ink-4);margin-top:2px}
.pl-step.done{background:var(--gov);border-color:var(--gov)}
.pl-step.done .m,.pl-step.done .n{color:#fff}
.pl-step.cur{background:var(--accent);border-color:var(--accent)}
.pl-step.cur .m,.pl-step.cur .n{color:#2a1f00}
.pl-step.bloq::after{content:"⚿";position:absolute;top:3px;right:5px;font-size:.6rem;opacity:.6}

/* ===== Tabs ===== */
.tabs{display:flex;flex-wrap:wrap;gap:2px;border-bottom:2px solid var(--line);margin-bottom:16px;background:var(--surface);border-radius:var(--r-lg) var(--r-lg) 0 0;padding:0 6px}
.tab{padding:11px 15px;font-size:.85rem;font-weight:500;color:var(--ink-3);border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer}
.tab:hover{color:var(--ink)}
.tab.active{color:var(--gov);border-bottom-color:var(--gov);font-weight:600}
.tab .pill{margin-left:5px;background:var(--surface-2);color:var(--ink-3);font-size:.64rem;padding:1px 6px;border-radius:8px;font-weight:700}
.tab.active .pill{background:var(--gov-light);color:var(--gov)}

/* ===== Bloco ===== */
.bloco{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;margin-bottom:14px}
.bloco-h{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:15px 20px;border-bottom:1px solid var(--line);background:var(--surface-2)}
.bloco-h .tt{display:flex;align-items:center;gap:12px}
.bloco-h .letra{width:30px;height:30px;border-radius:6px;background:var(--gov);color:#fff;font-family:var(--serif);font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.bloco-h h4{font-family:var(--sans);font-size:.95rem;font-weight:600}
.bloco-h .sub{font-size:.76rem;color:var(--ink-3);margin-top:1px}
.bloco-b{padding:20px}
.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 26px}
.field{display:flex;flex-direction:column;gap:5px}
.field.full{grid-column:1/-1}
.field label{font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-3)}
.field .v{font-size:.9rem;line-height:1.5;white-space:pre-wrap}
.field .v.empty{color:var(--ink-4);font-style:italic}
.field input,.field select,.field textarea{border:1px solid var(--line);border-radius:var(--r);padding:8px 10px;font-size:.88rem;background:var(--surface);width:100%}
.field textarea{min-height:84px;resize:vertical;font-family:inherit;line-height:1.5}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gov);box-shadow:0 0 0 3px rgba(29,52,97,.12)}
.field .help{font-size:.72rem;color:var(--ink-4)}
.field .help.ok{color:var(--green)}
.field .help.bad{color:var(--warning)}

/* ===== Entrada (Bloco C/D) ===== */
.entrada{border:1px solid var(--line);border-radius:var(--r);margin-bottom:10px;background:var(--surface)}
.entrada-h{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 15px;cursor:pointer}
.entrada-h:hover{background:var(--surface-2)}
.entrada-h .info{display:flex;align-items:center;gap:9px;flex-wrap:wrap;flex:1;min-width:0}
.entrada-h .info .e{font-weight:600;font-size:.88rem}
.entrada-h .data{font-family:var(--mono);font-size:.74rem;color:var(--ink-3);white-space:nowrap}
.entrada-b{padding:16px;border-top:1px solid var(--line);display:none}
.entrada.open .entrada-b{display:block}
.entrada-b .row{display:grid;grid-template-columns:150px 1fr;gap:7px 18px;margin-bottom:10px;font-size:.86rem}
.entrada-b .row .l{font-size:.74rem;font-weight:600;color:var(--ink-3)}
.divider{height:1px;background:var(--line);margin:12px 0}
.rtri-pill{display:inline-flex;align-items:center;gap:4px;font-size:.68rem;font-weight:600;padding:2px 7px;border-radius:3px;background:#d8f5e3;color:#0a4520;border:1px solid #a8d6b8}
.rtri-pill.na{background:var(--surface-2);color:var(--ink-3);border-color:var(--line)}
.rtri-pill.pend{background:#fff7e0;color:#8a5a00;border-color:#f0d997}

/* ===== Comprovativo ===== */
.cmp-code{font-family:var(--mono);font-size:.74rem;background:var(--gov-dark);color:#e7eaf0;padding:13px 15px;border-radius:var(--r);word-break:break-all;line-height:1.85;border:1px solid var(--gov)}
.cmp-code .h{color:#8fb4e8}.cmp-code .p{color:#e7eaf0}.cmp-code .s{color:var(--accent)}
.cmp-meta{display:flex;flex-wrap:wrap;gap:13px;font-size:.74rem;color:var(--ink-3);margin-top:9px}
.cmp-meta b{color:var(--ink-2);font-weight:600}
.cmp-flow{display:flex;gap:7px;margin:16px 0}
.cmp-flow .node{flex:1;border:1px solid var(--line);border-radius:var(--r);padding:13px 10px;text-align:center;background:var(--surface-2)}
.cmp-flow .node .ic{width:30px;height:30px;margin:0 auto 7px;border-radius:50%;background:var(--gov);color:#fff;display:flex;align-items:center;justify-content:center}
.cmp-flow .node.sl .ic{background:var(--accent);color:#2a1f00}
.cmp-flow .node .ic svg{width:15px;height:15px}
.cmp-flow .node .t{font-size:.78rem;font-weight:600}
.cmp-flow .node .d{font-size:.68rem;color:var(--ink-3);margin-top:2px;line-height:1.35}
.cmp-flow .arrow{display:flex;align-items:center;color:var(--ink-4);font-size:.64rem;font-weight:700}
.cmp-row{display:flex;align-items:center;gap:11px;padding:11px 13px;border-bottom:1px solid var(--line-2);font-size:.84rem}
.cmp-row:last-child{border-bottom:none}
.cmp-mark{width:30px;height:30px;flex-shrink:0;border-radius:6px;background:var(--gov);color:#fff;font-family:var(--mono);font-weight:700;font-size:.76rem;display:flex;align-items:center;justify-content:center}
.cmp-mark.pend{background:var(--surface-2);color:var(--ink-4);border:1px dashed var(--line)}
.cmp-jti{font-family:var(--mono);font-size:.72rem;color:var(--ink-3)}
.cmp-badge{font-size:.64rem;font-weight:700;padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.03em}
.cmp-badge.valido{background:#d8f5e3;color:#0a4520}
.cmp-badge.pend{background:var(--surface-2);color:var(--ink-4)}
.cmp-badge.verif{background:var(--gov);color:#fff}

/* ===== Timeline ===== */
.timeline{position:relative;padding-left:22px}
.timeline::before{content:"";position:absolute;left:6px;top:4px;bottom:4px;width:2px;background:var(--line)}
.tl-item{position:relative;padding-bottom:15px}
.tl-item::before{content:"";position:absolute;left:-22px;top:3px;width:14px;height:14px;border-radius:50%;background:var(--surface);border:2px solid var(--gov)}
.tl-item.marco::before{background:var(--accent);border-color:var(--accent)}
.tl-item .ts{font-size:.72rem;color:var(--ink-4);font-family:var(--mono)}
.tl-item .desc{font-size:.86rem}
.tl-item .desc b{color:var(--gov)}
.tl-item .who{font-size:.76rem;color:var(--ink-3)}

/* ===== Alert ===== */
.alert{padding:13px 16px;border-radius:var(--r);font-size:.88rem;margin-bottom:14px;border-left:3px solid;background:var(--surface-2);line-height:1.5}
.alert .at{font-weight:600;display:block;margin-bottom:3px}
.alert.info{border-color:var(--gov);background:var(--gov-light);color:var(--gov-dark)}
:root[data-theme="dark"] .alert.info{color:var(--ink)}
.alert.success{border-color:var(--green);background:rgba(15,120,88,.08);color:var(--green)}
.alert.warning{border-color:var(--warning);background:rgba(163,101,7,.09);color:var(--warning)}
.alert.danger{border-color:var(--red);background:rgba(167,23,40,.08);color:var(--red)}

/* ===== Checklist ===== */
.checklist{list-style:none;margin:10px 0}
.checklist li{display:flex;gap:11px;align-items:flex-start;padding:7px 0;font-size:.88rem}
.checklist li::before{content:"";width:18px;height:18px;border-radius:5px;flex-shrink:0;margin-top:1px;background-size:13px;background-repeat:no-repeat;background-position:center}
.checklist li.ok::before{background-color:var(--green);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='4' stroke-linecap='round'%3E%3Cpath d='M5 12l5 5L20 7'/%3E%3C/svg%3E")}
.checklist li.bad::before{background-color:var(--red);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='4' stroke-linecap='round'%3E%3Cpath d='M6 6l12 12M18 6L6 18'/%3E%3C/svg%3E")}
.checklist li.bad{color:var(--red)}
.checklist .det{font-size:.78rem;color:var(--ink-3);margin-top:2px}
.declaracao{background:var(--gov-light);border-left:3px solid var(--gov);padding:14px 17px;font-family:var(--serif);font-style:italic;font-size:.95rem;color:var(--gov-dark);margin:13px 0;line-height:1.5}
:root[data-theme="dark"] .declaracao{color:var(--ink)}

/* ===== Modal ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(11,19,33,.6);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:200;padding:20px;animation:fade .15s ease}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal{background:var(--surface);border-radius:var(--r-lg);width:100%;max-width:600px;max-height:92vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:pop .18s ease}
.modal.lg{max-width:780px}
@keyframes pop{from{transform:translateY(12px) scale(.98);opacity:0}to{transform:none;opacity:1}}
.modal-h{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:17px 22px;border-bottom:1px solid var(--line)}
.modal-h h3{font-family:var(--sans);font-size:1.08rem;font-weight:600}
.modal-b{padding:20px 22px}
.modal-f{display:flex;justify-content:flex-end;gap:9px;padding:15px 22px;border-top:1px solid var(--line);background:var(--surface-2)}
.x-btn{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--ink-3);font-size:1.1rem}
.x-btn:hover{background:var(--surface-2);color:var(--ink)}

/* ===== RTRI search ===== */
.rtri-search{position:relative}
.rtri-results{position:absolute;top:100%;left:0;right:0;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);margin-top:3px;max-height:230px;overflow-y:auto;z-index:10;box-shadow:var(--shadow);display:none}
.rtri-results.open{display:block}
.rtri-res{padding:9px 12px;border-bottom:1px solid var(--line-2);cursor:pointer}
.rtri-res:last-child{border-bottom:none}
.rtri-res:hover{background:var(--surface-2)}
.rtri-res .rn{font-size:.85rem;font-weight:500}
.rtri-res .rd{font-size:.72rem;color:var(--ink-3);margin-top:1px}

/* ===== Toasts ===== */
.toast-stack{position:fixed;top:16px;right:16px;z-index:300;display:flex;flex-direction:column;gap:8px;max-width:370px}
.toast{background:var(--surface);border:1px solid var(--line);border-left:3px solid var(--gov);border-radius:var(--r);padding:11px 14px;box-shadow:var(--shadow-lg);font-size:.85rem;animation:slidein .2s ease}
.toast.success{border-left-color:var(--green)}
.toast.error{border-left-color:var(--red)}
.toast.warning{border-left-color:var(--warning)}
.toast .tt{font-weight:600;margin-bottom:1px}
@keyframes slidein{from{transform:translateX(20px);opacity:0}to{transform:none;opacity:1}}

/* ===== Dropdown (user menu) ===== */
.dropdown{position:absolute;top:52px;right:14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);min-width:230px;z-index:60;overflow:hidden}
/* No modo painel, o dropdown abre por cima da sidebar (canto inferior esq.) */
.painel-mode .dropdown{position:fixed;top:auto;right:auto;left:210px;bottom:60px;border-color:var(--p-border);min-width:240px}
.painel-mode .notif-panel{position:fixed;top:auto;right:auto;left:210px;bottom:60px;border-color:var(--p-border);width:360px;max-width:calc(100vw - 220px)}
.dropdown .dh{padding:13px 16px;border-bottom:1px solid var(--line);background:var(--surface-2)}
.dropdown .dh .n{font-weight:600;font-size:.88rem}
.dropdown .dh .e{font-size:.76rem;color:var(--ink-3)}
.dropdown button{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:9px 16px;font-size:.85rem;color:var(--ink-2)}
.dropdown button:hover{background:var(--surface-2);color:var(--ink)}
.dropdown button svg{width:15px;height:15px;opacity:.7}
.dropdown .sep{height:1px;background:var(--line)}

/* ===== Notif panel ===== */
.notif-panel{position:absolute;top:52px;right:56px;width:340px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);z-index:60;overflow:hidden}
.notif-panel .nh{display:flex;align-items:center;justify-content:space-between;padding:12px 15px;border-bottom:1px solid var(--line);background:var(--surface-2);font-weight:600;font-size:.86rem}
.notif-list{max-height:380px;overflow-y:auto}
.notif{display:flex;gap:11px;padding:11px 15px;border-bottom:1px solid var(--line-2);cursor:pointer}
.notif:hover{background:var(--surface-2)}
.notif.unread{background:var(--gov-light)}
.notif.unread:hover{background:var(--gov-light)}
.notif .ni{width:30px;height:30px;border-radius:50%;background:var(--gov);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.notif .ni svg{width:15px;height:15px}
.notif .nc .nt{font-size:.83rem;font-weight:500;line-height:1.35}
.notif .nc .nm{font-size:.74rem;color:var(--ink-3);margin-top:2px}

/* ===== Misc ===== */
.flex{display:flex}.ac{align-items:center}.gap-8{gap:8px}.gap-12{gap:12px}.wrap{flex-wrap:wrap}
.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}
.spacer{flex:1}
.bar{display:flex;align-items:center;gap:10px;margin-bottom:7px}
.bar .bl{width:135px;font-size:.8rem;flex-shrink:0}
.bar .bt{flex:1;height:17px;background:var(--surface-2);border-radius:3px;overflow:hidden}
.bar .bf{height:100%;background:var(--gov);display:flex;align-items:center;padding:0 7px;color:#fff;font-size:.68rem;font-weight:700}

@media (max-width:980px){
  .kpis{grid-template-columns:repeat(2,1fr)}
  .grid-2{grid-template-columns:1fr}
  .field-grid{grid-template-columns:1fr}
  .role-grid{grid-template-columns:1fr}
  .sidebar{display:none}
  .main{padding:18px}
  .topbar nav{display:none}
  .pipeline{flex-wrap:wrap}
  .pl-step{min-width:62px}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ════════════════════════════════════════════════════════════════════════
   PAINEL v1.2 — sidebar escura + cabeçalho + stepper + grid de cards +
   cronograma. Aplicado no shell autenticado da demonstração.
   Hex values do design handoff brainstorming/design_handoff_fpl_painel/.
   ════════════════════════════════════════════════════════════════════════ */
:root{
  --p-bg:#f1f4f8;
  --p-side:#0c1729;
  --p-side-soft:#1f2945;
  --p-side-divider:#15203a;
  --p-side-fg:#cdd5e3;
  --p-side-mute:#7886a0;
  --p-text:#0c1729;
  --p-text-mute:#5b6478;
  --p-text-faint:#9aa5b6;
  --p-text-mid:#3a4658;
  --p-border:#d9e0ea;
  --p-border-hair:#eef0f3;
  --p-surface:#ffffff;
  --p-surface-alt:#fafbfc;
  --p-surface-alt2:#eef0f3;
  --p-gold:#b08020;
  --p-gold-bg:#fff8e6;
  --p-gold-border:#f3d27a;
  --p-success:#1a7f3c;
  --p-success-bg:#e6fcf0;
  --p-success-bdr:#86d8a0;
  --p-danger:#b81e2d;
  --p-danger-bg:#fef2f3;
  --p-danger-bdr:#f1adb0;
  --p-blue:#0a3161;
  --p-red:#c8102e;
  --p-mono:'IBM Plex Mono',ui-monospace,'SF Mono','Consolas',monospace;
}
:root[data-theme="dark"]{
  --p-bg:#0e131c;
  --p-surface:#161c28;
  --p-surface-alt:#1c2331;
  --p-surface-alt2:#242d3f;
  --p-text:#e7eaf0;
  --p-text-mute:#a8b3c7;
  --p-text-faint:#7886a0;
  --p-text-mid:#c0c6d2;
  --p-border:#2a3550;
  --p-border-hair:#1f2a40;
  --p-gold-bg:#3d2a05;
  --p-success-bg:#0d3320;
  --p-danger-bg:#3a1116;
}

/* App grid */
body.painel-mode{background:var(--p-bg)}
.painel-app{display:flex;height:100vh;width:100%;overflow:hidden;font-size:13px;color:var(--p-text);background:var(--p-bg)}

/* ── Sidebar escura ── */
.painel-side{width:200px;flex-shrink:0;background:var(--p-side);color:var(--p-side-fg);display:flex;flex-direction:column}
.painel-side .brand{padding:14px 16px;border-bottom:1px solid var(--p-side-soft);display:flex;align-items:center;gap:10px}
.painel-side .brand .crest-mini{width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.08);color:#fff;display:flex;align-items:center;justify-content:center}
.painel-side .brand .crest-mini svg{width:16px;height:16px}
.painel-side .brand-text{line-height:1.2}
.painel-side .brand-name{color:#fff;font-weight:700;font-size:13px;font-family:var(--sans)}
.painel-side .brand-sub{font-size:10.5px;opacity:.6;margin-top:1px}
.painel-side .group{padding:12px 8px;border-bottom:1px solid var(--p-side-divider)}
.painel-side .group-title{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--p-side-mute);font-weight:700;padding:0 8px;margin-bottom:6px}
.painel-side .link{display:flex;align-items:center;gap:9px;padding:8px 10px;font-size:12.5px;color:var(--p-side-fg);background:transparent;border:none;border-radius:4px;cursor:pointer;margin-bottom:1px;min-height:32px;width:100%;text-align:left;font-family:inherit;text-decoration:none;line-height:1.2}
.painel-side .link:hover{background:var(--p-side-soft);text-decoration:none}
.painel-side .link.active{background:var(--p-side-soft);color:#fff}
.painel-side .link svg{width:14px;height:14px;flex-shrink:0;opacity:.75}
.painel-side .link .pill{margin-left:auto;font-size:10px;font-weight:700;padding:1px 6px;background:var(--p-gold);color:var(--p-side);border-radius:99px}
.painel-side .link .dot-unread{margin-left:auto;width:7px;height:7px;border-radius:99px;background:var(--p-red)}
.painel-side .bottom{margin-top:auto;padding:12px 14px;border-top:1px solid var(--p-side-soft);display:flex;align-items:center;gap:8px;font-size:11.5px}
.painel-side .bottom .av{width:26px;height:26px;border-radius:50%;color:#fff;font-weight:700;font-size:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.painel-side .bottom .nm{line-height:1.25;min-width:0;flex:1}
.painel-side .bottom .nm strong{color:#fff;font-weight:600;display:block;font-size:11.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.painel-side .bottom .nm span{color:var(--p-side-mute);font-size:10.5px}
.painel-side .bottom button{color:var(--p-side-mute);background:none;border:none;cursor:pointer;padding:4px}
.painel-side .bottom button:hover{color:#fff}
.painel-side button.link:focus-visible{outline:2px solid var(--p-gold);outline-offset:-1px}

/* ── Main column ── */
.painel-main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;position:relative}
.painel-main-inner{flex:1;overflow:auto;padding:24px 28px}
.painel-main-inner.no-padding{padding:0}

/* Banner de demonstração — apenas no topo da main column */
.demo-banner-top{background:var(--accent);color:#2a1f00;text-align:center;font-size:.74rem;font-weight:600;letter-spacing:.04em;padding:5px 14px;flex-shrink:0}
.demo-banner-top button{text-decoration:underline;font-weight:700;background:none;border:none;color:inherit;cursor:pointer;font-family:inherit;font-size:inherit}

/* ── Header do painel ── */
.painel-head{background:var(--p-surface);border-bottom:1px solid var(--p-border);padding:14px 24px 0;flex-shrink:0}
.painel-bcrumb{font-size:11.5px;color:var(--p-text-mute);margin-bottom:6px;font-family:var(--p-mono)}
.painel-bcrumb button{background:none;border:none;color:inherit;text-decoration:none;cursor:pointer;font-family:inherit;font-size:inherit;padding:0}
.painel-bcrumb button:hover{text-decoration:underline}
.painel-title-row{display:flex;align-items:baseline;gap:14px;margin-bottom:12px;flex-wrap:wrap}
.painel-title{font-size:19px;font-weight:600;color:var(--p-text);line-height:1.3;letter-spacing:-.2px;flex:1;min-width:0;font-family:var(--sans)}
.painel-estado{font-size:11.5px;font-weight:700;padding:3px 10px;border-radius:99px;background:var(--p-gold-bg);color:#7a5400;border:1px solid var(--p-gold-border);white-space:nowrap}
.painel-estado.s-criado{background:#eaeef5;color:#5b6478;border-color:#cfd6df}
.painel-estado.s-elaboracao{background:var(--p-gold-bg);color:#7a5400;border-color:var(--p-gold-border)}
.painel-estado.s-consulta{background:#dbeafe;color:#1e3a8a;border-color:#93c5fd}
.painel-estado.s-rse{background:#e9d5ff;color:#5b21b6;border-color:#c4b5fd}
.painel-estado.s-cm{background:var(--p-danger-bg);color:#7c1c08;border-color:var(--p-danger-bdr)}
.painel-estado.s-aprovado{background:var(--p-success-bg);color:#0a4520;border-color:var(--p-success-bdr)}
.painel-estado.s-publicado{background:var(--p-side);color:#fff;border-color:var(--p-side)}
.painel-estado.s-revisao{background:#ffe9d3;color:#9a3412;border-color:#fdba74}
.painel-meta{display:flex;gap:8px;font-size:11.5px;color:var(--p-text-mute);margin-bottom:14px;flex-wrap:wrap;align-items:center}
.painel-meta .pill-tag{padding:2px 8px;background:#eef0f3;color:var(--p-text-mid);border-radius:3px;font-weight:600;font-size:11px}
.painel-meta .sep{color:var(--p-text-faint)}

/* View toggle */
.painel-toggle{display:inline-flex;margin-left:auto;background:var(--p-bg);border:1px solid var(--p-border);border-radius:6px;padding:3px}
.painel-toggle button{background:transparent;color:var(--p-text-mid);border:none;padding:6px 14px;border-radius:4px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;min-height:32px;display:inline-flex;align-items:center;gap:6px;transition:all .15s}
.painel-toggle button[aria-selected="true"]{background:var(--p-side);color:#fff}
.painel-toggle button:focus-visible{outline:2px solid var(--p-gold);outline-offset:1px}

/* Stepper M0..M5 */
.painel-stepper{display:grid;grid-template-columns:repeat(6,1fr);border-top:1px solid var(--p-border-hair);padding:14px 0}
.painel-step{position:relative;padding:0 14px;display:flex;align-items:flex-start;gap:10px;border-right:1px solid var(--p-border-hair)}
.painel-step:last-child{border-right:none}
.painel-step.todo{opacity:.6}
.painel-step .dot{width:28px;height:28px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;font-family:var(--p-mono);background:var(--p-border-hair);color:var(--p-text-faint);border:2px solid var(--p-border)}
.painel-step.done .dot{background:var(--p-blue);color:#fff;border-color:var(--p-blue)}
.painel-step.current .dot{background:var(--p-surface);color:var(--p-gold);border:2.5px solid var(--p-gold)}
.painel-step .lbl{font-size:12px;font-weight:600;color:var(--p-text);line-height:1.25}
.painel-step .sub{font-size:10.5px;color:var(--p-text-mute);margin-top:2px;font-family:var(--p-mono)}
.painel-step .bloq{display:inline-block;margin-left:4px;font-size:9.5px;color:var(--p-gold);font-weight:700}
.painel-step .cta{margin-top:6px;background:var(--p-gold);border:none;color:#fff;padding:5px 10px;font-size:11px;font-weight:700;border-radius:3px;cursor:pointer;font-family:inherit;letter-spacing:.2px;min-height:28px}
.painel-step .cta:hover{background:#8f6818}
.painel-step.skip{opacity:.45}
.painel-step.skip .lbl{text-decoration:line-through}

.pc-card-head .warn.cp-dispensada{margin-left:0;background:rgba(163,101,7,.12);color:var(--warning);border:1px solid rgba(163,101,7,.3);padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}

.btn-icon{background:none;border:none;cursor:pointer;color:var(--p-text-mute);padding:3px;border-radius:3px;display:inline-flex;align-items:center;justify-content:center;line-height:0;transition:background .12s ease,color .12s ease}
.btn-icon svg{width:13px;height:13px}
.btn-icon:hover{background:var(--p-surface-alt2,#eef0f3);color:var(--p-blue)}
.btn-icon:focus-visible{outline:2px solid var(--p-blue);outline-offset:1px}

.modal-b .confirm-msg{font-size:14px;color:var(--p-text);line-height:1.5}

/* ── Body Detalhe ── */
.painel-body{flex:1;overflow:auto;padding:18px 24px 24px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;grid-auto-rows:min-content;background:var(--p-bg)}
.pc-card{background:var(--p-surface);border:1px solid var(--p-border);border-radius:6px;overflow:hidden;display:flex;flex-direction:column}
.pc-card.wide{grid-column:1/-1}
.pc-card-head{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--p-border-hair);background:var(--p-surface-alt);cursor:pointer;user-select:none;transition:background .12s ease}
.pc-card-head:hover{background:var(--p-surface-alt2,#eef0f3)}
.pc-card-head:focus-visible{outline:2px solid var(--p-blue);outline-offset:-2px}
.pc-card.collapsed .pc-card-body{display:none}
.pc-card.collapsed .pc-card-head{border-bottom-color:transparent}
.pc-chev{margin-left:6px;display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;color:var(--p-text-mute);font-size:11px;line-height:1;transition:transform .18s ease,color .12s ease;flex-shrink:0}
.pc-card.collapsed .pc-chev{transform:rotate(-90deg);color:var(--p-text-faint,#9aa3b2)}
.pc-card-head:hover .pc-chev{color:var(--p-text)}
.painel-blk-actions{display:inline-flex;gap:6px;margin-left:8px}
.painel-blk-actions .btn{font-size:11px;padding:3px 8px}
.pc-letter{width:22px;height:22px;border-radius:3px;background:var(--p-blue);color:#fff;font-weight:700;font-size:11.5px;font-family:var(--p-mono);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pc-letter.d{background:var(--p-red)}
.pc-letter.cmp{background:var(--p-gold)}
.pc-letter.f,.pc-letter.h{background:#5b6478}
.pc-letter.anex{background:var(--p-success)}
.pc-card-head .ttl{font-size:13.5px;font-weight:600;color:var(--p-text);font-family:var(--sans)}
.pc-card-head .sub{font-size:11px;color:var(--p-text-mute)}
.pc-card-head .count{margin-left:auto;font-size:11.5px;font-weight:700;color:var(--p-text-mute);font-family:var(--p-mono)}
.pc-card-head .warn{margin-left:auto;font-size:11px;color:var(--p-gold);font-weight:700;background:var(--p-gold-bg);padding:2px 8px;border-radius:3px;border:1px solid var(--p-gold-border)}
.pc-card-head .ok{margin-left:auto;font-size:11px;color:var(--p-success);font-weight:700}
.pc-card-head button.more{background:none;border:none;cursor:pointer;font-family:inherit;font-size:11.5px;color:var(--p-blue);font-weight:600;padding:0 4px}
.pc-card-head button.more:hover{text-decoration:underline}
.pc-card-body{padding:12px 14px;font-size:12.5px;line-height:1.55;color:var(--p-text)}

.pc-kv{display:grid;grid-template-columns:120px 1fr;gap:6px 12px}
.pc-kv .k{font-size:11px;color:var(--p-text-mute);text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.pc-kv .v{font-size:12.5px;color:var(--p-text);word-break:break-word}
.pc-kv .v.mono{font-family:var(--p-mono);font-size:11.5px}
.pc-kv .v.empty{color:var(--p-text-faint);font-style:italic}

.pc-mini{display:grid;grid-template-columns:60px 1fr auto;gap:10px;align-items:center;padding:6px 0;border-bottom:1px dashed var(--p-border-hair);font-size:12px}
.pc-mini:last-child{border-bottom:none}
.pc-mini-date{font-size:11px;font-family:var(--p-mono);color:var(--p-text-mute)}
.pc-mini-ent{font-size:12px;font-weight:600;color:var(--p-text);line-height:1.3}
.pc-mini-sub{font-size:11px;color:var(--p-text-mute);margin-top:1px}

.pc-dec{font-size:10.5px;font-weight:700;padding:1px 6px;border-radius:3px;white-space:nowrap;background:#f3f3f5;color:#5b6478;border:1px solid #cfd6df}
.pc-dec.INCORPORADA{background:var(--p-success-bg);color:#0a4520;border-color:var(--p-success-bdr)}
.pc-dec.PARCIALMENTE_INCORPORADA{background:var(--p-gold-bg);color:#7a5400;border-color:var(--p-gold-border)}
.pc-dec.NAO_INCORPORADA{background:var(--p-danger-bg);color:#7c1c08;border-color:var(--p-danger-bdr)}
.pc-dec.SEM_OBJETO{background:#f3f3f5;color:#5b6478;border-color:#cfd6df}
.pc-dec.PENDENTE{background:var(--p-gold-bg);color:#7a5400;border-color:var(--p-gold-border)}

.pc-bar{display:flex;height:7px;border-radius:99px;overflow:hidden;background:var(--p-border-hair);margin:8px 0}
.pc-bar>div{height:100%}
.pc-bar-legend{display:flex;gap:18px;font-size:11px;color:var(--p-text-mute);margin-bottom:10px;flex-wrap:wrap}
.pc-bar-legend strong{font-size:12px}

.pc-sig{font-family:var(--p-mono);font-size:10.5px;color:var(--p-text-mute);background:#f4f6fa;border:1px solid var(--p-border);border-radius:4px;padding:6px 8px;margin-top:8px;word-break:break-all;line-height:1.4}
:root[data-theme="dark"] .pc-sig{background:#0d1320}

.pc-quote{font-style:italic;color:var(--p-text-mid);font-size:12.5px;padding:8px 12px;background:#f4f6fa;border-left:3px solid var(--p-blue);border-radius:3px;line-height:1.55}
:root[data-theme="dark"] .pc-quote{background:#0d1320}

.pc-more{font-size:11.5px;color:var(--p-blue);padding:8px 0 0;cursor:pointer;font-weight:600;background:none;border:none;font-family:inherit}
.pc-more:hover{text-decoration:underline}

.pc-empty{font-size:12px;color:var(--p-text-mute);font-style:italic}

/* ── Cronograma ── */
.painel-crono{flex:1;overflow:hidden;display:grid;grid-template-columns:1fr 320px;gap:0;background:var(--p-bg)}
.crono-cal{padding:18px 24px;overflow:auto}
.crono-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.crono-nav{display:flex;gap:6px}
.crono-nav button{width:32px;height:32px;border-radius:6px;background:var(--p-surface);border:1px solid var(--p-border);color:var(--p-text-mid);font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-family:inherit}
.crono-nav button:hover{background:var(--p-surface-alt)}
.crono-title{font-size:17px;font-weight:600;color:var(--p-text);letter-spacing:-.2px;text-transform:capitalize;font-family:var(--sans)}
.crono-legend{margin-left:auto;display:flex;gap:14px;font-size:11px;color:var(--p-text-mute);align-items:center;flex-wrap:wrap}
.crono-legend i{display:inline-block;width:8px;height:8px;border-radius:99px;margin-right:5px}
.crono-weekhead{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;font-size:10.5px;letter-spacing:1.2px;text-transform:uppercase;color:var(--p-text-mute);font-weight:700;margin-bottom:6px;padding:0 2px}
.crono-weekhead .cell{text-align:right;padding:0 6px}
.crono-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-auto-rows:1fr;gap:6px;min-height:480px}
.crono-cell{background:var(--p-surface);border:1px solid var(--p-border-hair);border-radius:6px;padding:6px 7px;overflow:hidden;display:flex;flex-direction:column;gap:3px}
.crono-cell.today{background:var(--p-gold-bg);border:1.5px solid var(--p-gold)}
.crono-cell.dim{opacity:.35}
.crono-cell .num{font-size:11.5px;font-weight:600;color:var(--p-text-mid);text-align:right;font-family:var(--p-mono)}
.crono-cell.today .num{color:var(--p-gold);font-weight:700}
.crono-ev{font-size:10.5px;padding:2px 6px;border-radius:3px;line-height:1.25;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;border:none;font-family:inherit;text-align:left;display:block;border-left-style:solid;border-left-width:3px}
.crono-ev.M0,.crono-ev.M1,.crono-ev.M2{background:#e6f0fb;color:var(--p-blue);border-left-color:var(--p-blue)}
.crono-ev.M3,.crono-ev.M4{background:var(--p-gold-bg);color:#7a5400;border-left-color:var(--p-gold)}
.crono-ev.M5{background:var(--p-success-bg);color:#0a4520;border-left-color:var(--p-success)}
.crono-ev.INTER{background:#f3f3f5;color:var(--p-text-mid);border-left-color:var(--p-text-faint)}
.crono-ev.RSE,.crono-ev.CM{background:var(--p-danger-bg);color:#7c1c08;border-left-color:var(--p-red)}
.crono-ev.CP{background:#eef0f3;color:var(--p-text-mid);border-left-color:var(--p-text-mute)}
.crono-ev.DR{background:var(--p-success-bg);color:#0a4520;border-left-color:var(--p-success)}

.crono-side{background:var(--p-surface);border-left:1px solid var(--p-border);overflow:auto;padding:20px 18px}
.crono-side-hdr{font-size:11px;letter-spacing:1.4px;text-transform:uppercase;color:var(--p-text-mute);font-weight:700;margin-bottom:14px}
.crono-up-row{display:grid;grid-template-columns:44px 1fr;gap:12px;padding:12px 0;border-bottom:1px solid var(--p-border-hair)}
.crono-up-row:last-of-type{border-bottom:none}
.crono-up-date{color:#fff;border-radius:6px;text-align:center;padding:6px 4px;height:fit-content}
.crono-up-date.blue{background:var(--p-blue)}
.crono-up-date.gold{background:var(--p-gold)}
.crono-up-date.green{background:var(--p-success)}
.crono-up-date.red{background:var(--p-red)}
.crono-up-date .month{font-size:9.5px;letter-spacing:1.2px;text-transform:uppercase;opacity:.85;font-weight:700}
.crono-up-date .day{font-size:17px;font-weight:700;line-height:1;margin-top:1px;font-family:var(--p-mono)}
.crono-up-title{font-size:13px;font-weight:600;color:var(--p-text);line-height:1.3;font-family:var(--sans)}
.crono-up-sub{font-size:11.5px;color:var(--p-text-mute);margin-top:3px;line-height:1.45}
.crono-up-tag{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.4px;padding:1px 6px;border-radius:3px;background:transparent;border:1px solid currentColor;margin-right:6px}
.crono-up-tag.M3,.crono-up-tag.M4{color:var(--p-gold)}
.crono-up-tag.M5,.crono-up-tag.DR{color:var(--p-success)}
.crono-up-tag.RSE,.crono-up-tag.CM{color:var(--p-red)}

/* Responsivo */
@media (max-width:1100px){
  .painel-body{grid-template-columns:minmax(0,1fr)}
  .painel-crono{grid-template-columns:minmax(0,1fr)}
  .crono-side{border-left:none;border-top:1px solid var(--p-border)}
}
@media (max-width:900px){
  .painel-side{display:none}
  .painel-stepper{grid-template-columns:repeat(3,1fr)}
}

/* ════════════════════════════════════════════════════════════════════════
   LOGIN v1.2 — ecrã de entrada redesenhado com sidebar institucional
   à esquerda + área de seleção de perfil agrupada à direita.
   ════════════════════════════════════════════════════════════════════════ */
.entrada-painel{display:flex;min-height:100vh;background:var(--p-bg);font-family:var(--sans);color:var(--p-text)}

.entrada-side{width:380px;flex-shrink:0;background:linear-gradient(180deg,var(--p-side) 0%,#06122a 100%);color:#cdd5e3;padding:36px 32px 24px;display:flex;flex-direction:column;gap:32px}
.entrada-brand{display:flex;flex-direction:column;gap:6px}
.entrada-brand .brand-crest{width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.08);color:var(--p-gold);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.entrada-brand .brand-crest svg{width:24px;height:24px}
.entrada-brand .brand-name{color:#fff;font-size:20px;font-weight:700;letter-spacing:-.3px;font-family:var(--sans)}
.entrada-brand .brand-sub{font-size:13px;color:var(--p-side-mute);letter-spacing:.3px}

.entrada-tagline{flex:1}
.entrada-tagline h2{color:#fff;font-size:24px;font-weight:600;letter-spacing:-.3px;line-height:1.25;margin-bottom:14px;font-family:var(--sans)}
.entrada-tagline p{font-size:14px;line-height:1.6;color:#cdd5e3;margin-bottom:20px}
.entrada-feat{list-style:none;padding:0;margin:24px 0 0;display:flex;flex-direction:column;gap:14px}
.entrada-feat li{display:flex;gap:12px;align-items:flex-start;font-size:13px;line-height:1.5;color:#cdd5e3}
.entrada-feat .ico{flex-shrink:0;width:28px;height:28px;border-radius:6px;background:rgba(176,128,32,.15);color:var(--p-gold);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}
.entrada-feat strong{color:#fff;font-weight:600}

.entrada-foot{font-size:11px;color:var(--p-side-mute);line-height:1.6;border-top:1px solid var(--p-side-soft);padding-top:18px}

/* Coluna principal */
.entrada-main{flex:1;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;padding:48px 56px;overflow-y:auto}
.entrada-corpo{max-width:760px;width:100%;margin:0 auto;display:flex;flex-direction:column;gap:32px}

.entrada-corpo header .kicker{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--p-gold);font-weight:700;display:block;margin-bottom:8px}
.entrada-corpo header h1{font-size:32px;font-weight:600;letter-spacing:-.5px;color:var(--p-text);line-height:1.2;margin-bottom:10px;font-family:var(--sans)}
.entrada-corpo header p{font-size:14px;color:var(--p-text-mute);line-height:1.6;max-width:600px}

.grupo-titulo{display:flex;align-items:center;gap:10px;font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--p-text-mute);font-weight:700;margin-bottom:12px}
.grupo-titulo .num{width:22px;height:22px;border-radius:50%;background:var(--p-side);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;font-family:var(--p-mono)}

.role-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.role-card{display:flex;align-items:center;gap:14px;padding:14px;background:var(--p-surface);border:1px solid var(--p-border);border-radius:8px;cursor:pointer;text-align:left;font-family:inherit;color:var(--p-text);transition:all .15s;width:100%}
.role-card:hover{border-color:var(--p-side);transform:translateY(-1px);box-shadow:0 4px 14px rgba(12,23,41,.08)}
.role-card.destaque{border-color:var(--p-gold);background:linear-gradient(135deg,#fff 0%,#fffbf0 100%);position:relative}
.role-card.destaque::after{content:'recomendado';position:absolute;top:-8px;right:14px;background:var(--p-gold);color:#fff;font-size:9px;letter-spacing:.5px;text-transform:uppercase;font-weight:700;padding:2px 8px;border-radius:99px}
.role-card .avatar{width:40px;height:40px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}
.role-card .meta{flex:1;display:flex;flex-direction:column;line-height:1.3;min-width:0}
.role-card .meta .nome{font-size:14px;font-weight:600;color:var(--p-text)}
.role-card .meta .papel{font-size:12px;color:var(--p-text-mute);margin-top:2px}
.role-card .meta .email{font-size:11px;color:var(--p-text-faint);margin-top:3px;font-family:var(--p-mono);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.role-card .seta{color:var(--p-text-faint);font-size:18px;flex-shrink:0;transition:transform .15s}
.role-card:hover .seta{color:var(--p-side);transform:translateX(2px)}
.role-card.destaque .seta{color:var(--p-gold)}

.mais-perfis{margin-top:8px}
.mais-perfis summary{cursor:pointer;font-size:12.5px;color:var(--p-blue);font-weight:600;padding:8px 0;list-style:none}
.mais-perfis summary::-webkit-details-marker{display:none}
.mais-perfis summary::before{content:'+';display:inline-block;margin-right:6px;font-weight:700}
.mais-perfis[open] summary::before{content:'−'}
.mais-perfis summary:hover{text-decoration:underline}

.entrada-aviso{background:var(--p-gold-bg);border:1px solid var(--p-gold-border);border-radius:6px;padding:14px 16px;font-size:13px;color:#5a3d00;line-height:1.5}
.entrada-aviso strong{color:#3d2900}

@media (max-width:1100px){
  .entrada-painel{flex-direction:column}
  .entrada-side{width:100%;padding:24px}
  .entrada-tagline{flex:initial}
  .entrada-feat{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
  .entrada-feat li{font-size:12px}
  .entrada-main{padding:32px 24px}
}
@media (max-width:760px){
  .role-grid{grid-template-columns:1fr}
  .entrada-feat{grid-template-columns:1fr}
}

/* ── Trigger do menu de utilizador (sidebar bottom) ── */
.painel-side .bottom.user-trigger{cursor:pointer;background:none;border:none;width:100%;font-family:inherit;text-align:left;padding:12px 14px;border-top:1px solid var(--p-side-soft);display:flex;align-items:center;gap:8px;color:#cdd5e3;transition:background .15s}
.painel-side .bottom.user-trigger:hover{background:rgba(255,255,255,.04)}
.painel-side .bottom.user-trigger:focus-visible{outline:2px solid var(--p-gold);outline-offset:-2px}
.painel-side .bottom .caret{margin-left:auto;color:var(--p-side-mute);font-size:14px;transform:rotate(180deg);transition:transform .15s}
.painel-side .bottom.user-trigger[aria-expanded="true"] .caret{transform:rotate(0deg)}

/* ════════════════════════════════════════════════════════════════════════
   v1.3 — Refinamentos: chips de filtros, sortable, scroll-to-card,
   page-load anim, sse-dot. Replicação do refactor da app.
   ════════════════════════════════════════════════════════════════════════ */

/* Chips de filtros ativos */
.chips{display:flex;gap:6px;flex-wrap:wrap;margin:0 0 12px;font-family:var(--sans)}
.chip{display:inline-flex;align-items:center;gap:6px;padding:3px 4px 3px 10px;border-radius:99px;background:var(--gov-light);color:var(--gov);border:1px solid rgba(10,49,97,.2);font-size:11px;font-weight:600}
.chip .x{width:18px;height:18px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:rgba(10,49,97,.12);color:var(--gov);font-size:11px;font-weight:700;cursor:pointer;border:none;font-family:inherit}
.chip .x:hover{background:rgba(10,49,97,.25)}

/* Tabela ordenável */
.tbl-sortable th[data-sort]{cursor:pointer;user-select:none;position:relative;padding-right:22px}
.tbl-sortable th[data-sort]::after{content:"";position:absolute;right:8px;top:50%;transform:translateY(-50%);width:8px;height:10px;opacity:.25;background:linear-gradient(to bottom,currentColor 45%,transparent 45%,transparent 55%,currentColor 55%)}
.tbl-sortable th.sort-asc::after{background:linear-gradient(to bottom,currentColor 45%,transparent 45%);opacity:1;color:var(--gov)}
.tbl-sortable th.sort-desc::after{background:linear-gradient(to bottom,transparent 55%,currentColor 55%);opacity:1;color:var(--gov)}
.tbl-sortable th[data-sort]:hover{color:var(--gov)}

/* Scroll-to-card highlight */
.pc-card.highlight{animation:cardHighlightDemo 1.2s ease-out}
@keyframes cardHighlightDemo{
  0%{box-shadow:0 0 0 0 rgba(176,128,32,0)}
  20%{box-shadow:0 0 0 3px rgba(176,128,32,.75)}
  100%{box-shadow:0 0 0 0 rgba(176,128,32,0)}
}

/* Page-load anim — cards do detalhe entram escalonados */
.painel-body .pc-card{animation:fadeUpDemo .35s ease both}
.painel-body .pc-card:nth-child(1){animation-delay:0ms}
.painel-body .pc-card:nth-child(2){animation-delay:40ms}
.painel-body .pc-card:nth-child(3){animation-delay:80ms}
.painel-body .pc-card:nth-child(4){animation-delay:120ms}
.painel-body .pc-card:nth-child(5){animation-delay:160ms}
.painel-body .pc-card:nth-child(6){animation-delay:200ms}
.painel-body .pc-card:nth-child(7){animation-delay:240ms}
.painel-body .pc-card:nth-child(8){animation-delay:280ms}
@keyframes fadeUpDemo{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* Stepper navegável */
.painel-step{cursor:pointer;transition:background-color .15s}
.painel-step:hover{background:var(--surface-2)}
.painel-step[role="button"]:focus-visible{outline:2px solid var(--p-gold);outline-offset:-2px}

/* SSE indicator (sidebar) */
.painel-side .link .sse-dot{margin-left:auto;width:8px;height:8px;border-radius:50%;background:var(--ink-4)}
.painel-side .link .sse-dot.live{background:#22c55e;box-shadow:0 0 0 3px rgba(34,197,94,.25)}
.painel-side .link .sse-dot.polling{background:var(--accent)}

/* Modal de reset com input de confirmação */
.reset-modal input{width:100%;padding:10px 12px;border:2px solid var(--line);border-radius:var(--r);font-family:var(--mono);font-size:14px;letter-spacing:.05em;background:var(--surface);color:var(--ink);margin-top:8px}
.reset-modal input:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(199,23,40,.15)}

/* ── Dropdown do utilizador (estilo painel) ── */
.painel-mode .dropdown{padding:0;min-width:280px}
.painel-mode .dropdown .dh{padding:14px 16px}
.painel-mode .dropdown .dh-top{display:flex;gap:11px;align-items:center;margin-bottom:8px}
.painel-mode .dropdown .dh-avatar{width:36px;height:36px;border-radius:50%;color:#fff;font-weight:700;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.painel-mode .dropdown .dh .n{font-weight:600;font-size:14px;line-height:1.2}
.painel-mode .dropdown .dh .e{font-size:11.5px;color:var(--p-text-mute);font-family:var(--p-mono);margin-top:2px}
.painel-mode .dropdown .dh-papel{font-size:11px;color:var(--p-text-faint);text-transform:uppercase;letter-spacing:.4px;font-weight:600}
.painel-mode .dropdown button{padding:10px 16px;font-size:13px;display:flex;align-items:center;gap:10px}
.painel-mode .dropdown button.danger{color:var(--p-danger)}
.painel-mode .dropdown button.danger:hover{background:var(--p-danger-bg)}
.painel-mode .dropdown button svg{width:15px;height:15px;flex-shrink:0;opacity:.7}
