:root{--tf-bg:#121519;--tf-surface:#1B1E23;--tf-surface-2:#242A33;--tf-line-dark:#2E3640;
--tf-blue:#3FA7D6;--tf-green:#6CC04A;--tf-teal:#2BB4C9;--tf-silver:#C8CDD4;
--tf-text-dark:#E6EAF0;--tf-muted-dark:#8A93A0;
--bg:#F5F7FA;--surface:#FFFFFF;--line:#E3E8EF;--ink:#14202E;--text:#1F2733;--muted:#6B7787}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font:16px/1.6 'Plus Jakarta Sans',sans-serif;font-weight:500;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:'Space Grotesk',sans-serif;font-weight:700}
a{color:var(--tf-blue);text-decoration:none}a:hover{text-decoration:underline}
.login-wrap{min-height:100vh;background:var(--tf-bg);display:flex;align-items:center;justify-content:center}
.login-card{background:var(--tf-surface);border-radius:14px;padding:2.5rem;width:380px;max-width:95vw;box-shadow:0 20px 60px rgba(0,0,0,.4)}
.login-logo{text-align:center;margin-bottom:1.5rem}
.login-logo h1{font-size:1.3rem;color:var(--tf-text-dark);letter-spacing:.08em}
.login-logo p{font-size:.8rem;color:var(--tf-blue);letter-spacing:.2em;margin-top:4px}
.login-card h2{font-size:1rem;color:var(--tf-text-dark);margin-bottom:1.25rem;text-align:center}
.login-card .form-group label{color:var(--tf-muted-dark)}
.login-card input{background:var(--tf-surface-2);border-color:var(--tf-line-dark);color:var(--tf-text-dark)}
.login-card input:focus{border-color:var(--tf-blue)}
.login-card input::placeholder{color:var(--tf-muted-dark)}
.shell{display:flex;height:100vh;overflow:hidden}
.sidebar{width:220px;flex-shrink:0;background:var(--tf-surface);display:flex;flex-direction:column;border-right:1px solid var(--tf-line-dark)}
.main{flex:1;overflow-y:auto;background:var(--bg)}
.main-inner{padding:1.75rem;max-width:1200px}
.sb-logo{padding:1.25rem 1rem .875rem;border-bottom:1px solid var(--tf-line-dark)}
.sb-logo h1{font-size:.95rem;color:var(--tf-text-dark);letter-spacing:.06em}
.sb-logo p{font-size:.6rem;color:var(--tf-blue);letter-spacing:.18em;margin-top:2px}
.sb-nav{flex:1;padding:.5rem 0;overflow-y:auto}
.nav-section{padding:.5rem 1rem .2rem;font:600 .65rem/1 'Space Grotesk',sans-serif;color:var(--tf-muted-dark);text-transform:uppercase;letter-spacing:.1em;margin-top:.25rem}
.nav-item{display:flex;align-items:center;gap:9px;padding:9px 16px;color:var(--tf-muted-dark);cursor:pointer;font-size:.95rem;font-weight:500;border-left:3px solid transparent;transition:.15s;user-select:none}
.nav-item:hover{color:var(--tf-text-dark);background:rgba(255,255,255,.04)}
.nav-item.active{color:var(--tf-blue);border-left-color:var(--tf-blue);background:rgba(63,167,214,.08)}
.nav-item svg{flex-shrink:0;width:15px;height:15px}
.sb-footer{padding:.875rem 1rem;border-top:1px solid var(--tf-line-dark)}
.sb-user{font-size:.82rem;color:var(--tf-muted-dark);margin-bottom:.4rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.vault-bar{display:flex;align-items:center;justify-content:space-between;padding:.35rem .75rem;margin:0 -.25rem .4rem;border-radius:6px;background:rgba(0,0,0,.2)}
.vault-status{font-size:.8rem;font-weight:600;color:var(--tf-muted-dark)}
.vault-status.unlocked{color:var(--tf-green)}
.page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem;gap:1rem;flex-wrap:wrap}
.page-hdr h1{font-size:1.4rem;color:var(--ink)}
.page-sub{font-size:.95rem;color:var(--muted);margin-top:.15rem}
.breadcrumb{font-size:.88rem;color:var(--muted);margin-bottom:.35rem}
.bc-link{color:var(--tf-blue);cursor:pointer}.bc-link:hover{text-decoration:underline}
.card{background:var(--surface);border-radius:10px;box-shadow:0 1px 4px rgba(0,0,0,.06);padding:1.25rem;margin-bottom:1rem}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.875rem;margin-bottom:1.25rem}
.stat-card{border-left:4px solid var(--tf-blue);cursor:default}
.stat-card:nth-child(2){border-color:var(--tf-green)}.stat-card:nth-child(3){border-color:var(--tf-teal)}.stat-card:nth-child(4){border-color:var(--tf-silver)}
.stat-num{font:700 1.8rem/1 'Space Grotesk',sans-serif;color:var(--ink)}
.stat-lbl{font-size:.82rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-top:.3rem}
.sec-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:.875rem}
.sec-title{font:600 .9rem/1 'Space Grotesk',sans-serif;color:var(--ink)}
.sec-actions{display:flex;gap:.5rem}
.tbl{width:100%;border-collapse:collapse;font-size:.85rem}
.tbl th{text-align:left;padding:.55rem .75rem;font:600 .7rem/1 'Space Grotesk',sans-serif;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--line)}
.tbl td{padding:.65rem .75rem;border-bottom:1px solid var(--line);vertical-align:top}
.tbl tr:last-child td{border-bottom:none}
.tbl tbody tr:hover td{background:var(--bg)}
.tbl tbody tr[data-action]{cursor:pointer}
.cred-tbl td{border-right:1px solid var(--line)}
.cred-tbl td:last-child{border-right:none}
.cred-tbl tbody tr:nth-child(even) td{background:color-mix(in srgb,var(--bg) 60%,var(--surface) 40%)}
.cred-tbl tbody tr[data-cred-row-id]:hover td{background:var(--bg);cursor:pointer}
.badge{display:inline-flex;align-items:center;padding:.18rem .5rem;border-radius:5px;font:600 .68rem/1 'Space Grotesk',sans-serif;letter-spacing:.02em;white-space:nowrap}
/* Status */
.s-active{background:#DCFCE7;color:#166534}
.r-owner{background:#EDE9FE;color:#5B21B6}.r-staff{background:#E0F2FE;color:#075985}.s-inactive{background:#F1F5F9;color:#475569}
.s-paused{background:#FEF3C7;color:#92400E}.s-archived{background:#F1F5F9;color:#64748B}
.s-planning{background:#EDE9FE;color:#5B21B6}.s-maintenance{background:#FFF7ED;color:#9A3412}
.s-deprecated{background:#FEF2F2;color:#991B1B}.s-needs_review{background:#FEF3C7;color:#92400E}
.s-provisioning{background:#E0F2FE;color:#0369A1}.s-retired{background:#F1F5F9;color:#94A3B8}
/* Priority */
.p-low{background:#F1F5F9;color:#475569}.p-normal{background:#E0F2FE;color:#075985}
.p-high{background:#FEF3C7;color:#92400E}.p-urgent{background:#FEE2E2;color:#991B1B}
/* Issue type */
.t-bug{background:#FEE2E2;color:#991B1B}.t-outage{background:#FFE4E1;color:#7F1D1D}.t-suggestion{background:#EDE9FE;color:#5B21B6}
.t-question{background:#FEF9C3;color:#713F12}.t-task{background:#E0F2FE;color:#0369A1}
.t-change_request{background:#FFF7ED;color:#9A3412}.t-access{background:#FEE2E2;color:#9A1515}.t-other{background:#F1F5F9;color:#475569}
/* Issue status */
.is-new{background:#DBEAFE;color:#1E40AF}.is-acknowledged{background:#E0F2FE;color:#075985}.is-in_progress{background:#FEF3C7;color:#92400E}
.is-planned{background:#EDE9FE;color:#5B21B6}.is-resolved{background:#DCFCE7;color:#166534}
.is-declined{background:#F1F5F9;color:#475569}
/* Criticality */
.cr-low{background:#F1F5F9;color:#475569}.cr-normal{background:#E0F2FE;color:#0369A1}
.cr-high{background:#FFF7ED;color:#9A3412}.cr-critical{background:#FEE2E2;color:#991B1B}
/* Ownership */
.ow-internal{background:#DBEAFE;color:#1E40AF}.ow-customer{background:#DCFCE7;color:#166534}
.ow-vendor{background:#EDE9FE;color:#5B21B6}.ow-unknown{background:#FEF3C7;color:#92400E}
/* Provider type */
.pt-cloud_hosting{background:#E0F2FE;color:#0369A1}.pt-dns{background:#EDE9FE;color:#5B21B6}
.pt-email{background:#FFF7ED;color:#9A3412}.pt-repository{background:#F0FDF4;color:#166534}
/* Resource type */
.rt-vm_server{background:#DBEAFE;color:#1E40AF}.rt-database{background:#EDE9FE;color:#5B21B6}
.rt-domain{background:#DCFCE7;color:#166534}.rt-dns_zone{background:#F0F9FF;color:#0369A1}
/* Source */
.src-admin{background:#F1F5F9;color:#475569}.src-portal{background:#E0F2FE;color:#075985}
.btn{display:inline-flex;align-items:center;gap:5px;padding:.4rem .875rem;border-radius:6px;border:none;cursor:pointer;font:.82rem/1 'Plus Jakarta Sans',sans-serif;font-weight:600;transition:.15s;text-decoration:none!important}
.btn:disabled{opacity:.5;cursor:default}
.btn-primary{background:var(--tf-blue);color:#fff}.btn-primary:hover:not(:disabled){background:#3496c2}
.btn-green{background:var(--tf-green);color:#fff}.btn-green:hover:not(:disabled){background:#5aad3c}
.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--line)}.btn-ghost:hover:not(:disabled){background:var(--bg)}
.btn-danger{background:#DC2626;color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}
.btn-sm{padding:.28rem .6rem;font-size:.85rem}
.btn-link{background:none;border:none;color:var(--tf-blue);cursor:pointer;font:.82rem 'Plus Jakarta Sans',sans-serif;font-weight:500;padding:0}.btn-link:hover{text-decoration:underline}
.filter-bar{display:flex;gap:.6rem;margin-bottom:1rem;flex-wrap:wrap;align-items:center}
.filter-bar input{flex:1;min-width:160px;max-width:260px}
.filter-bar select{min-width:120px}
.modal-ov{position:fixed;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;z-index:900}
.modal{background:var(--surface);border-radius:12px;padding:1.75rem;width:540px;max-width:95vw;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.2)}
.modal-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}
.modal-title{font:600 1.05rem/1 'Space Grotesk',sans-serif;color:var(--ink)}
.modal-close{background:none;border:none;cursor:pointer;color:var(--muted);font-size:1.3rem;line-height:1;padding:0 .2rem}
.modal-footer{display:flex;justify-content:space-between;align-items:center;margin-top:1.25rem;padding-top:.875rem;border-top:1px solid var(--line)}
.modal-footer .right{display:flex;gap:.5rem}
.form-group{margin-bottom:.875rem}
.form-group label{display:block;font:600 .72rem/1 'Plus Jakarta Sans',sans-serif;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.3rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.875rem}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.875rem}
input,select,textarea{width:100%;padding:.45rem .7rem;border:1px solid var(--line);border-radius:6px;font:.875rem/1.5 'Plus Jakarta Sans',sans-serif;color:var(--text);background:var(--surface);transition:.15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--tf-blue);box-shadow:0 0 0 3px rgba(63,167,214,.12)}
textarea{resize:vertical;min-height:72px}
input[type=checkbox]{width:auto;cursor:pointer}
.check-row{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem}
.tab-bar{display:flex;gap:0;border-bottom:2px solid var(--line);margin-bottom:1.25rem;overflow-x:auto;scrollbar-width:none}
.tab-bar::-webkit-scrollbar{display:none}
.tab-btn{flex-shrink:0;padding:.5rem .875rem;border:none;background:none;cursor:pointer;font:.78rem/1 'Space Grotesk',sans-serif;font-weight:600;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-2px;white-space:nowrap;transition:.15s}
.tab-btn:hover{color:var(--ink)}.tab-btn.active{color:var(--tf-blue);border-bottom-color:var(--tf-blue)}
.tab-chip{display:inline-flex;align-items:center;justify-content:center;min-width:15px;height:14px;padding:0 3px;border-radius:7px;background:var(--muted);color:#fff;font-size:.6rem;margin-left:3px;vertical-align:middle}
.tab-chip.warn{background:#DC2626}
.empty{text-align:center;padding:2.5rem 1rem;color:var(--muted);font-size:.875rem}
.loading{text-align:center;padding:2rem;color:var(--muted);font-size:.875rem}
.mono{font-family:'Courier New',monospace;font-size:.8rem;word-break:break-all}
.bw-note{font-size:.82rem;color:var(--muted);font-style:italic;margin-top:.35rem;display:block}
.warn-chip{display:inline-flex;align-items:center;gap:3px;background:#FEF3C7;color:#92400E;font:600 .68rem/1 'Space Grotesk',sans-serif;padding:.18rem .45rem;border-radius:4px}
.warn-chip.hot{background:#FEE2E2;color:#991B1B}
.detail-meta{display:flex;gap:.45rem;flex-wrap:wrap;align-items:center;margin-top:.35rem}
.portal-box{background:var(--bg);border:1px solid var(--line);border-radius:6px;padding:.5rem .7rem;font-family:'Courier New',monospace;font-size:.88rem;word-break:break-all}
#toast{position:fixed;bottom:1.25rem;right:1.25rem;background:var(--ink);color:#fff;padding:.7rem 1.1rem;border-radius:8px;font-size:.95rem;display:none;z-index:9999;box-shadow:0 4px 20px rgba(0,0,0,.2);max-width:300px}
#toast.t-error{background:#DC2626}#toast.t-success{background:var(--tf-green)}
hr{border:none;border-top:1px solid var(--line);margin:.75rem 0}
.alloc-bar-wrap{display:flex;align-items:center;gap:.5rem;font-size:.88rem}
.alloc-bar{flex:1;height:6px;background:var(--line);border-radius:3px;overflow:hidden;min-width:60px}
.alloc-bar i{display:block;height:100%;background:var(--tf-blue);border-radius:3px;transition:.3s}
.alloc-bar i.over{background:#DC2626}
.stack-checks{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.35rem}
.chk-item{display:flex;align-items:center;gap:.4rem;font-size:.8rem}
.chk-dot{width:16px;height:16px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;flex-shrink:0}
.chk-ok .chk-dot{background:#DCFCE7;color:#166534}.chk-no .chk-dot{background:#FEE2E2;color:#991B1B}
.chk-no{color:var(--muted)}
.vault-card{border:1px solid var(--line);border-radius:8px;padding:.75rem 1rem;margin-bottom:.5rem;cursor:pointer;transition:.15s}
.vault-card:hover,.vault-card.active{border-color:var(--tf-blue);background:#F0F9FF}
.cred-card{border:1px solid var(--line);border-radius:8px;padding:.875rem 1rem;margin-bottom:.5rem}
.cred-card.warn-rotation{border-color:#F59E0B;background:#FFFBEB}
.secret-field{background:var(--bg);border:1px solid var(--line);border-radius:6px;padding:.45rem .7rem;font-family:'Courier New',monospace;font-size:.8rem;word-break:break-all;margin:.25rem 0}
.resource-services{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem;margin-top:.75rem}
.svc-card{border:1px solid var(--line);border-radius:8px;padding:.875rem;background:var(--bg)}
.svc-card h4{font-size:.875rem;color:var(--ink);margin-bottom:.25rem}
.tog{position:relative;display:inline-block;width:40px;height:22px;flex-shrink:0}
.tog input{opacity:0;width:0;height:0;position:absolute}
.tog-track{position:absolute;inset:0;background:#D1D5DB;border-radius:11px;cursor:pointer;transition:.2s}
.tog input:checked+.tog-track{background:var(--tf-green)}
.tog-track::before{content:'';position:absolute;width:16px;height:16px;border-radius:50%;background:#fff;left:3px;top:3px;transition:.2s}
.tog input:checked+.tog-track::before{transform:translateX(18px)}
.tog-wrap{display:flex;align-items:center;gap:.6rem;font-size:.875rem}
/* ── SIDEBAR v2 ── */
.sidebar{width:236px;background:linear-gradient(180deg,#1D2127 0%,#16191E 100%);border-right:none;display:flex;flex-direction:column;min-height:100vh;flex-shrink:0}
.sb-brand{padding:1.1rem 1rem .75rem;display:flex;flex-direction:column;align-items:center;gap:.45rem;border-bottom:1px solid rgba(255,255,255,.07);position:relative}
.sb-logo-img{max-width:160px;height:auto}
.sb-app{font-family:'Space Grotesk',sans-serif;font-size:9.5px;letter-spacing:.26em;color:var(--tf-blue);font-weight:600;text-transform:uppercase}
.sb-nav{flex:1;overflow-y:auto;padding:.5rem 0}
.nav-sec{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--tf-muted-dark);padding:.7rem 18px .2rem;margin-top:1rem}
.nav-sec:first-child{margin-top:0}
.nav-item{display:flex;align-items:center;gap:.55rem;margin:1px 10px;padding:8px 12px;border-radius:8px;color:var(--tf-text-dark);cursor:pointer;font-size:.95rem;transition:.1s;user-select:none}
.nav-item svg{width:16px;height:16px;flex-shrink:0}
.nav-item:hover{background:rgba(255,255,255,.05);color:#CBD5E1}
.nav-item.active{background:rgba(63,167,214,.14);color:#8FCBE9;font-weight:600}
.nav-count{display:inline-flex;align-items:center;justify-content:center;margin-left:auto;min-width:17px;height:17px;border-radius:99px;background:#DC2626;color:#fff;font-size:10px;font-weight:700;padding:0 4px}
.sb-footer{border-top:1px solid rgba(255,255,255,.07);padding:.6rem .5rem}
.sb-vault{display:flex;align-items:center;gap:.5rem;padding:.4rem .65rem;border-radius:8px;margin-bottom:.25rem}
.sb-vault svg{width:14px;height:14px;color:#A8B5C3;flex-shrink:0}
.sb-vault-lbl{font-size:.85rem;color:#D0DAE5;flex:1}
.vault-btn{font-size:.8rem;padding:.2rem .55rem;border-radius:99px;border:1px solid rgba(152,162,174,.5);background:transparent;color:#A8B5C3;cursor:pointer;white-space:nowrap;transition:.1s}
.vault-btn:hover{border-color:var(--tf-blue);color:var(--tf-blue)}
.sb-userrow{display:flex;align-items:center;gap:.6rem;padding:.4rem .65rem;border-radius:8px}
.sb-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--tf-blue),var(--tf-teal));display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:#fff;flex-shrink:0}
.sb-uinfo{flex:1;min-width:0}
.sb-uname{font-size:.85rem;font-weight:600;color:#CBD5E1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-uemail{font-size:.65rem;color:#A8B5C3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-signout{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(152,162,174,.4);border-radius:6px;background:transparent;cursor:pointer;color:#A8B5C3;flex-shrink:0;transition:.1s}
.sb-signout:hover{border-color:var(--tf-blue);color:var(--tf-blue)}
.sb-toggle{position:absolute;top:.75rem;right:1rem;width:32px;height:32px;border:1px solid rgba(255,255,255,.2);background:transparent;color:var(--tf-muted-dark);cursor:pointer;font-size:1.2rem;padding:0;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:.2s}
.sb-toggle:hover{color:var(--tf-text-dark);border-color:rgba(255,255,255,.35)}
.sidebar.collapsed{width:70px}
.sidebar.collapsed .sb-nav{display:none}
.sidebar.collapsed .sb-footer{display:none}
.sidebar.collapsed .sb-brand{padding:.5rem}
.sidebar.collapsed .sb-brand img{display:none}
.sidebar.collapsed .nav-item span{display:none}
.sidebar.collapsed .nav-item{padding:.6rem .4rem;justify-content:center}
@keyframes spin{to{transform:rotate(360deg)}}
