/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   Foyl Identity Platform — Stylesheet
   Ficsit Inc. Pioneer Division
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

:root {
  --blue:#00AEEF; --cyan:#00D4FF; --teal:#00897B; --ocean:#005F87;
  --id:#8B5CF6; --id-lite:#A78BFA;
  --bg:#111009; --bg2:#161410; --surf:#1E1B15; --surf2:#262219; --surf3:#302C22;
  --border:rgba(255,245,210,.07); --border2:rgba(255,245,210,.13);
  --tx:#ECE6D6; --tx2:#B8AFA0; --tx3:#706860;
  --crit:#FC4444;   --crit-bg:rgba(252,68,68,.1);    --crit-b:rgba(252,68,68,.25);
  --high:#F59E0B;   --high-bg:rgba(245,158,11,.1);   --high-b:rgba(245,158,11,.25);
  --med:#FBBF24;    --med-bg:rgba(251,191,36,.08);   --med-b:rgba(251,191,36,.2);
  --low:#3B82F6;    --low-bg:rgba(59,130,246,.1);    --low-b:rgba(59,130,246,.25);
  --ok:#00897B;     --ok-bg:rgba(0,137,123,.1);      --ok-b:rgba(0,137,123,.25);
  --purple:#8B5CF6; --purple-bg:rgba(139,92,246,.1); --purple-b:rgba(139,92,246,.25);
  --danger:#C45A50; --warn:#C4942A;
  --id-bg:rgba(139,92,246,.1); --id-b:rgba(139,92,246,.25);
  --font:'Outfit',sans-serif; --mono:'DM Mono',monospace; --jakarta:'Plus Jakarta Sans',sans-serif;
}
[data-theme="light"] {
  --bg:#F5F3EE; --bg2:#EDEAE3; --surf:#E4E0D8; --surf2:#DEDAD0; --surf3:#D0CBBD;
  --border:rgba(60,50,30,.09); --border2:rgba(60,50,30,.16);
  --tx:#1A1610; --tx2:#4A4030; --tx3:#8A7A60;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;overflow:hidden;}
body{background:var(--bg);color:var(--tx);font-family:var(--font);font-weight:300;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;display:flex;flex-direction:column;}
a{color:inherit;text-decoration:none;}
button{cursor:pointer;border:none;background:none;font-family:inherit;color:inherit;font-size:inherit;}
input,select{font-family:inherit;color:inherit;}
::-webkit-scrollbar{width:6px;height:6px;}::-webkit-scrollbar-track{background:transparent;}::-webkit-scrollbar-thumb{background:var(--surf3);border-radius:3px;}
@keyframes fade-in{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes slide-in{from{transform:translateX(-8px);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes toast-in{from{opacity:0;transform:translateX(12px)}to{opacity:1;transform:translateX(0)}}

/* ── TOPBAR ── */
#topbar{height:48px;flex-shrink:0;background:var(--bg2);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 16px;gap:0;z-index:100;}
.tb-logo{display:flex;align-items:center;gap:8px;margin-right:8px;text-decoration:none;}
.tb-logo img{height:16px;width:auto;}
.tb-product{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--id-lite);background:var(--id-bg);border:1px solid var(--id-b);padding:2px 8px;border-radius:3px;}
.tb-sep{width:1px;height:20px;background:var(--border2);margin:0 14px;}
.tb-instance{font-family:var(--mono);font-size:10px;color:var(--tx2);letter-spacing:.06em;display:flex;align-items:center;gap:6px;}
.tb-instance-dot{width:6px;height:6px;border-radius:50%;background:var(--ok);animation:pulse 3s infinite;}
.tb-right{margin-left:auto;display:flex;align-items:center;gap:16px;}
.tb-stat{display:flex;align-items:center;gap:5px;font-family:var(--mono);font-size:10px;color:var(--tx3);}
.tb-stat-val{color:var(--tx);font-weight:400;}
.tb-stat-val.warn{color:var(--high);}
.tb-stat-val.danger{color:var(--crit);}
.tb-clock{font-family:var(--mono);font-size:11px;color:var(--tx2);}
.tb-theme-btn{font-family:var(--mono);font-size:10px;color:var(--tx3);padding:4px 10px;border-radius:5px;border:1px solid var(--border2);background:transparent;cursor:pointer;transition:all .15s;}
.tb-theme-btn:hover{background:var(--surf);color:var(--tx2);}

/* ── LAYOUT ── */
#app-body{flex:1;display:flex;overflow:hidden;}
#sidebar{width:220px;flex-shrink:0;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;}
.sb-section{padding:8px 0;border-bottom:1px solid var(--border);}
.sb-section:last-of-type{border-bottom:none;}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 16px;font-size:13px;color:var(--tx3);font-weight:400;transition:background .12s,color .12s;cursor:pointer;text-decoration:none;position:relative;}
.nav-item:hover{background:var(--surf);color:var(--tx2);}
.nav-item.active{color:var(--blue);background:rgba(0,174,239,.08);}
.nav-item.active::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--blue);border-radius:0 2px 2px 0;}
.nav-item svg{flex-shrink:0;opacity:.7;}
.nav-item.active svg{opacity:1;}
.nav-badge{margin-left:auto;font-family:var(--mono);font-size:9px;background:var(--crit-bg);color:var(--crit);border:1px solid var(--crit-b);padding:1px 6px;border-radius:10px;min-width:20px;text-align:center;}
.nav-badge.warn{background:var(--high-bg);color:var(--high);border-color:var(--high-b);}
.nav-badge.info{background:var(--id-bg);color:var(--id-lite);border-color:var(--id-b);}
.nav-badge.ok{background:var(--ok-bg);color:var(--ok);border-color:var(--ok-b);}
.sb-footer{margin-top:auto;border-top:1px solid var(--border);padding:12px 16px;}
.sb-version{font-family:var(--mono);font-size:9px;color:var(--tx3);letter-spacing:.06em;line-height:1.8;}
#main{flex:1;overflow-y:auto;display:flex;flex-direction:column;}

/* ── PAGE STRUCTURE ── */
.page{flex:1;}
.page-header{padding:20px 28px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:16px;flex-shrink:0;}
.page-title{font-family:var(--jakarta);font-size:18px;font-weight:600;letter-spacing:-.02em;}
.page-sub{font-size:13px;color:var(--tx3);margin-top:2px;}
.page-actions{margin-left:auto;display:flex;align-items:center;gap:8px;}
.content-wrap{padding:20px 28px 28px;}

/* ── STAT CARDS ── */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px;}
.stat-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px;}
.stat-card{background:var(--surf);border:1px solid var(--border);border-radius:8px;padding:16px 18px;position:relative;overflow:hidden;}
.stat-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--id);}
.stat-card.ok::before{background:var(--ok);}
.stat-card.warn::before{background:var(--high);}
.stat-card.danger::before{background:var(--crit);}
.stat-card.blue::before{background:var(--blue);}
.stat-label{font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--tx3);margin-bottom:8px;}
.stat-value{font-family:var(--jakarta);font-size:28px;font-weight:600;letter-spacing:-.03em;line-height:1;color:var(--tx);}
.stat-value.ok{color:var(--ok);}
.stat-value.warn{color:var(--high);}
.stat-value.danger{color:var(--crit);}
.stat-value.id{color:var(--id-lite);}
.stat-sub{font-size:11px;color:var(--tx3);margin-top:6px;}
.stat-sub .up{color:var(--ok);}
.stat-sub .dn{color:var(--crit);}

/* ── SECTION HEADER ── */
.section-hdr{display:flex;align-items:center;gap:12px;padding-bottom:10px;margin-bottom:14px;border-bottom:1px solid var(--border);}
.sh-title{font-family:var(--jakarta);font-size:14px;font-weight:600;letter-spacing:-.01em;flex:1;}
.sh-meta{font-family:var(--mono);font-size:11px;color:var(--tx3);}
.sh-meta .ok{color:var(--ok);}
.sh-meta .warn{color:var(--high);}
.sh-meta .danger{color:var(--crit);}

/* ── TABLE ── */
.data-table{width:100%;border-collapse:collapse;font-size:13px;}
.data-table th{font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--tx3);padding:8px 12px;text-align:left;border-bottom:1px solid var(--border2);white-space:nowrap;}
.data-table td{padding:9px 12px;border-bottom:1px solid var(--border);vertical-align:middle;}
.data-table tbody tr{transition:background .1s;cursor:pointer;}
.data-table tbody tr:hover{background:rgba(255,245,210,.025);}
.data-table tbody tr.selected{background:rgba(139,92,246,.08);}
.data-table tbody tr:last-child td{border-bottom:none;}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;gap:4px;font-family:var(--mono);font-size:10px;letter-spacing:.06em;padding:2px 7px;border-radius:3px;white-space:nowrap;font-weight:400;}
.badge.ok{color:var(--ok);background:var(--ok-bg);border:1px solid var(--ok-b);}
.badge.low{color:var(--low);background:var(--low-bg);border:1px solid var(--low-b);}
.badge.med,.badge.medium{color:var(--high);background:var(--high-bg);border:1px solid var(--high-b);}
.badge.high{color:var(--crit);background:var(--crit-bg);border:1px solid var(--crit-b);}
.badge.none{color:var(--ok);background:var(--ok-bg);border:1px solid var(--ok-b);}
.badge.info{color:var(--id-lite);background:var(--id-bg);border:1px solid var(--id-b);}
.badge.warn{color:var(--high);background:var(--high-bg);border:1px solid var(--high-b);}
.badge.danger{color:var(--crit);background:var(--crit-bg);border:1px solid var(--crit-b);}
.badge.neutral{color:var(--tx3);background:var(--surf2);border:1px solid var(--border2);}
.badge.purple{color:var(--purple);background:var(--purple-bg);border:1px solid var(--purple-b);}
.badge.blue{color:var(--blue);background:rgba(0,174,239,.1);border:1px solid rgba(0,174,239,.25);}
.badge.dot::before{content:'';display:inline-block;width:5px;height:5px;border-radius:50%;background:currentColor;}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;padding:6px 12px;border-radius:5px;cursor:pointer;transition:all .15s;border:1px solid var(--border2);background:var(--surf2);color:var(--tx2);white-space:nowrap;}
.btn:hover{background:var(--surf3);color:var(--tx);border-color:var(--border2);}
.btn.primary{background:var(--id-bg);color:var(--id-lite);border-color:var(--id-b);}
.btn.primary:hover{background:rgba(139,92,246,.2);}
.btn.danger{background:var(--crit-bg);color:var(--crit);border-color:var(--crit-b);}
.btn.danger:hover{background:rgba(252,68,68,.2);}
.btn.ok{background:var(--ok-bg);color:var(--ok);border-color:var(--ok-b);}
.btn.ok:hover{background:rgba(0,137,123,.2);}
.btn.warn{background:var(--high-bg);color:var(--high);border-color:var(--high-b);}
.btn.warn:hover{background:rgba(245,158,11,.2);}
.btn.blue{background:rgba(0,174,239,.1);color:var(--blue);border-color:rgba(0,174,239,.25);}
.btn.blue:hover{background:rgba(0,174,239,.2);}

/* ── TABS ── */
.tab-bar{display:flex;gap:2px;margin-bottom:0;border-bottom:1px solid var(--border);flex-shrink:0;}
.tab-btn{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:8px 14px;color:var(--tx3);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s;}
.tab-btn:hover{color:var(--tx2);}
.tab-btn.active{color:var(--id-lite);border-bottom-color:var(--id);}
.tab-panel{display:none;padding-top:20px;}
.tab-panel.active{display:block;}

/* ── SPLIT LAYOUT ── */
.id-split-layout{display:flex;height:calc(100vh - 48px);overflow:hidden;}
.id-list-panel{width:380px;flex-shrink:0;border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;}
.id-list-panel.wide{width:440px;}
.id-list-toolbar{padding:12px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;flex-shrink:0;background:var(--bg2);}
.id-search{flex:1;background:var(--surf);border:1px solid var(--border2);border-radius:5px;padding:6px 10px;font-size:12px;color:var(--tx);outline:none;font-family:var(--mono);}
.id-search::placeholder{color:var(--tx3);}
.id-search:focus{border-color:var(--id);}
.id-list-count{font-family:var(--mono);font-size:10px;color:var(--tx3);padding:6px 14px 6px;flex-shrink:0;border-bottom:1px solid var(--border);background:var(--bg2);}
.id-list-scroll{flex:1;overflow-y:auto;}

/* ── USER ROWS ── */
.user-row{display:flex;align-items:center;gap:12px;padding:11px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;border-left:2px solid transparent;}
.user-row:hover{background:rgba(255,245,210,.025);}
.user-row.selected{background:rgba(139,92,246,.08);border-left-color:var(--id);}
.user-avatar{width:32px;height:32px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:var(--jakarta);font-size:12px;font-weight:700;color:#fff;position:relative;}
.user-avatar.disabled{opacity:.45;}
.user-row-info{flex:1;min-width:0;}
.user-row-name{font-size:13px;font-weight:400;color:var(--tx);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.user-row-name.disabled{color:var(--tx3);text-decoration:line-through;}
.user-row-upn{font-family:var(--mono);font-size:10px;color:var(--tx3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px;}
.user-row-right{flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:4px;}
.risk-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.risk-dot.none{background:var(--ok);}
.risk-dot.low{background:var(--low);}
.risk-dot.medium{background:var(--high);}
.risk-dot.high{background:var(--crit);}

/* ── CA ROWS ── */
.ca-row{display:flex;align-items:center;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;border-left:2px solid transparent;}
.ca-row:hover{background:rgba(255,245,210,.025);}
.ca-row.selected{background:rgba(139,92,246,.08);border-left-color:var(--id);}
.ca-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.ca-status-dot.enabled{background:var(--ok);}
.ca-status-dot.disabled{background:var(--surf3);}
.ca-status-dot.report-only{background:var(--high);}
.ca-row-info{flex:1;min-width:0;}
.ca-row-name{font-size:13px;font-weight:400;color:var(--tx);}
.ca-row-meta{font-family:var(--mono);font-size:10px;color:var(--tx3);margin-top:2px;}

/* ── DEVICE ROWS ── */
.device-row{display:flex;align-items:center;gap:12px;padding:11px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;border-left:2px solid transparent;}
.device-row:hover{background:rgba(255,245,210,.025);}
.device-row.selected{background:rgba(139,92,246,.08);border-left-color:var(--id);}
.device-icon{width:32px;height:32px;border-radius:6px;flex-shrink:0;background:var(--surf2);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;}
.device-row-info{flex:1;min-width:0;}
.device-row-name{font-size:13px;color:var(--tx);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.device-row-meta{font-family:var(--mono);font-size:10px;color:var(--tx3);margin-top:2px;}

/* ── RISK ROWS ── */
.risk-row{display:flex;align-items:center;gap:12px;padding:11px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;border-left:2px solid transparent;}
.risk-row:hover{background:rgba(255,245,210,.025);}
.risk-row.selected{background:rgba(139,92,246,.08);border-left-color:var(--id);}
.risk-row-info{flex:1;min-width:0;}
.risk-row-name{font-size:13px;font-weight:400;color:var(--tx);}
.risk-row-sub{font-family:var(--mono);font-size:10px;color:var(--tx3);margin-top:2px;}
.risk-sev{width:4px;height:36px;border-radius:2px;flex-shrink:0;}
.risk-sev.high{background:var(--crit);}
.risk-sev.medium{background:var(--high);}
.risk-sev.low{background:var(--low);}

/* ── DETAIL PANEL ── */
.id-detail-panel{flex:1;overflow-y:auto;display:flex;flex-direction:column;}
.detail-empty{flex:1;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px;}
.detail-empty-icon{opacity:.12;}
.detail-empty-text{font-family:var(--mono);font-size:11px;color:var(--tx3);letter-spacing:.1em;}
.detail-action-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:12px 20px;background:var(--bg2);border-bottom:1px solid var(--border2);position:sticky;top:0;z-index:10;}
.detail-action-title{font-family:var(--jakarta);font-size:13px;font-weight:600;}
.detail-action-badges{display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
.detail-action-btns{display:flex;gap:6px;flex-wrap:wrap;margin-left:auto;}
.detail-content{padding:20px;flex:1;}

/* ── USER PROFILE CARD ── */
.user-profile-card{display:flex;align-items:center;gap:16px;background:var(--surf);border:1px solid var(--border);border-radius:8px;padding:16px 18px;margin-bottom:20px;}
.user-profile-avatar{width:52px;height:52px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:var(--jakarta);font-size:18px;font-weight:700;color:#fff;}
.user-profile-name{font-family:var(--jakarta);font-size:17px;font-weight:600;}
.user-profile-title{font-size:12px;color:var(--tx2);margin-top:2px;}
.user-profile-upn{font-family:var(--mono);font-size:10px;color:var(--tx3);margin-top:3px;}
.user-profile-badges{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px;}
.user-profile-meta{margin-left:auto;flex-shrink:0;text-align:right;font-family:var(--mono);font-size:10px;color:var(--tx3);line-height:1.8;}

/* ── INFO GRID ── */
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px;}
.info-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:20px;}
.info-card{background:var(--surf);border:1px solid var(--border);border-radius:7px;padding:12px 14px;}
.info-card-label{font-family:var(--mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--tx3);margin-bottom:6px;}
.info-card-value{font-size:13px;color:var(--tx);font-weight:400;}
.info-card-sub{font-family:var(--mono);font-size:10px;color:var(--tx3);margin-top:3px;}

/* ── RISK CARD ── */
.risk-alert-card{border-radius:7px;padding:14px 16px;margin-bottom:16px;background:var(--surf);border:1px solid var(--border);}
.risk-alert-card.high{border-color:var(--crit-b);background:rgba(252,68,68,.05);}
.risk-alert-card.medium{border-color:var(--high-b);background:rgba(245,158,11,.05);}
.risk-alert-card.low{border-color:var(--low-b);background:rgba(59,130,246,.05);}
.risk-alert-header{display:flex;align-items:center;gap:10px;margin-bottom:10px;}
.risk-alert-title{font-family:var(--jakarta);font-size:13px;font-weight:600;flex:1;}
.risk-alert-body{font-size:12px;color:var(--tx2);line-height:1.6;}
.risk-item{display:flex;align-items:flex-start;gap:8px;font-size:12px;color:var(--tx2);margin-top:4px;}
.risk-item::before{content:'→';color:var(--tx3);flex-shrink:0;}

/* ── SECURE SCORE ── */
.secure-score-card{background:var(--surf);border:1px solid var(--border);border-radius:8px;padding:20px;display:flex;align-items:center;gap:24px;margin-bottom:24px;}
.score-ring{width:80px;height:80px;border-radius:50%;border:4px solid var(--id);flex-shrink:0;display:flex;align-items:center;justify-content:center;flex-direction:column;}
.score-num{font-family:var(--jakarta);font-size:22px;font-weight:700;color:var(--id-lite);line-height:1;}
.score-denom{font-family:var(--mono);font-size:9px;color:var(--tx3);}
.score-info{flex:1;}
.score-title{font-family:var(--jakarta);font-size:14px;font-weight:600;margin-bottom:4px;}
.score-sub{font-size:12px;color:var(--tx2);line-height:1.5;}
.score-items{display:flex;flex-direction:column;gap:6px;margin-top:12px;}
.score-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--tx2);}
.score-item-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;}

/* ── BAR CHART ── */
.bar-chart{display:flex;align-items:flex-end;gap:6px;height:80px;padding:0 2px;}
.bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;}
.bar{width:100%;border-radius:3px 3px 0 0;background:var(--id-bg);border:1px solid var(--id-b);transition:height .3s;min-height:4px;}
.bar.danger{background:var(--crit-bg);border-color:var(--crit-b);}
.bar.warn{background:var(--high-bg);border-color:var(--high-b);}
.bar-label{font-family:var(--mono);font-size:9px;color:var(--tx3);}

/* ── SIGN-IN FILTERS ── */
.signin-filter-bar{padding:12px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;flex-wrap:wrap;flex-shrink:0;background:var(--bg2);}
.signin-search{flex:1;min-width:200px;background:var(--surf);border:1px solid var(--border2);border-radius:5px;padding:6px 10px;font-size:12px;color:var(--tx);outline:none;font-family:var(--mono);}
.signin-search::placeholder{color:var(--tx3);}
.signin-search:focus{border-color:var(--id);}
.filter-select{background:var(--surf);border:1px solid var(--border2);color:var(--tx2);border-radius:5px;padding:5px 8px;font-size:12px;outline:none;cursor:pointer;font-family:var(--mono);}
.filter-select:focus{border-color:var(--id);}
.signin-result-bar{padding:6px 20px;border-bottom:1px solid var(--border);font-family:var(--mono);font-size:10px;color:var(--tx3);display:flex;align-items:center;gap:12px;background:var(--bg2);flex-shrink:0;}

/* ── PIM ── */
.pim-role-row{display:flex;align-items:center;gap:14px;padding:13px 16px;border-bottom:1px solid var(--border);transition:background .1s;}
.pim-role-row:hover{background:rgba(255,245,210,.02);}
.pim-role-icon{width:36px;height:36px;border-radius:8px;flex-shrink:0;background:var(--id-bg);border:1px solid var(--id-b);display:flex;align-items:center;justify-content:center;}
.pim-role-info{flex:1;min-width:0;}
.pim-role-name{font-size:13px;font-weight:400;color:var(--tx);}
.pim-role-sub{font-family:var(--mono);font-size:10px;color:var(--tx3);margin-top:2px;}
.pim-role-actions{flex-shrink:0;display:flex;align-items:center;gap:8px;}
.pim-timer{font-family:var(--mono);font-size:10px;color:var(--high);background:var(--high-bg);border:1px solid var(--high-b);padding:2px 7px;border-radius:3px;}
.pim-timer.ok{color:var(--ok);background:var(--ok-bg);border-color:var(--ok-b);}

/* ── AUDIT LOG ── */
.audit-row{display:flex;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px solid var(--border);}
.audit-icon{width:28px;height:28px;border-radius:6px;flex-shrink:0;background:var(--surf2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;margin-top:1px;}
.audit-info{flex:1;min-width:0;}
.audit-action{font-size:12px;font-weight:400;color:var(--tx);}
.audit-who{font-family:var(--mono);font-size:10px;color:var(--tx3);margin-top:2px;}
.audit-ts{font-family:var(--mono);font-size:10px;color:var(--tx3);flex-shrink:0;}

/* ── DETAIL DRAWER (sign-ins) ── */
.detail-drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:200;display:none;}
.detail-drawer-overlay.open{display:block;}
.detail-drawer{position:fixed;right:0;top:0;bottom:0;width:480px;background:var(--bg2);border-left:1px solid var(--border2);z-index:201;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .25s cubic-bezier(.25,.46,.45,.94);}
.detail-drawer.open{transform:translateX(0);}
.drawer-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;flex-shrink:0;}
.drawer-title{font-family:var(--jakarta);font-size:14px;font-weight:600;flex:1;}
.drawer-close{width:28px;height:28px;border-radius:5px;background:var(--surf);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--tx3);transition:all .15s;}
.drawer-close:hover{color:var(--tx);background:var(--surf2);}
.drawer-body{flex:1;overflow-y:auto;padding:20px;}
.drawer-section{margin-bottom:20px;}
.drawer-section-title{font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--tx3);margin-bottom:10px;}
.drawer-kv{display:grid;grid-template-columns:120px 1fr;gap:6px 12px;font-size:12px;}
.drawer-kv-label{color:var(--tx3);font-family:var(--mono);font-size:10px;padding-top:1px;}
.drawer-kv-val{color:var(--tx);}

/* ── TOAST ── */
#toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column-reverse;gap:8px;pointer-events:none;}
.toast-item{background:var(--surf2);border:1px solid var(--border2);border-left:3px solid var(--id);border-radius:6px;padding:10px 16px;font-family:var(--mono);font-size:11px;color:var(--tx2);max-width:340px;line-height:1.4;animation:toast-in .2s ease;pointer-events:auto;}
.toast-item.ok{border-left-color:var(--ok);}
.toast-item.warn{border-left-color:var(--high);}
.toast-item.danger{border-left-color:var(--crit);}
.toast-item.info{border-left-color:var(--id);}

/* ── UTILITIES ── */
.mono{font-family:var(--mono);}
.section-block{margin-bottom:28px;}
.flex-row{display:flex;align-items:center;gap:8px;}
.ml-auto{margin-left:auto;}
.text-sm{font-size:12px;}
.color-ok{color:var(--ok);}
.color-warn{color:var(--high);}
.color-danger{color:var(--crit);}
.color-dim{color:var(--tx3);}
.color-id{color:var(--id-lite);}
.divider{height:1px;background:var(--border);margin:16px 0;}
