/* =========================================================
   NoFire SiGe-Tool — Stylesheet v0.2.0
   Brand: Rot #E30613 / Anthrazit / warme Grautöne
   ========================================================= */

:root{
  --nf-red:        #E30613;
  --nf-red-dark:   #B30410;
  --nf-red-soft:   #FCE8EA;
  --nf-red-soft2:  #F4C8CB;

  --ink-900: #1C1B1B;
  --ink-700: #3A3A3A;
  --ink-500: #6B6B6B;
  --ink-400: #9A9A9A;
  --ink-300: #C9C7C7;
  --ink-200: #E6E4E4;
  --ink-100: #F2F0F0;
  --ink-50:  #FAF9F8;

  --ok:      #1F7A3A;
  --ok-soft: #E5F4E9;
  --warn:    #B8651A;
  --warn-soft:#FBEFE0;
  --info:    #2563B0;
  --info-soft:#E2EDF8;

  --shadow-sm: 0 1px 2px rgba(28,27,27,.06), 0 1px 1px rgba(28,27,27,.04);
  --shadow-md: 0 4px 12px rgba(28,27,27,.08), 0 2px 4px rgba(28,27,27,.04);
  --radius:   8px;
  --radius-sm:6px;
  --sidebar:  260px;
  --transition: 160ms cubic-bezier(.2,.8,.2,1);

  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--ink-50);color:var(--ink-900);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
button{font-family:inherit}
a{color:var(--nf-red);text-decoration:none}
a:hover{text-decoration:underline}

.app{display:grid;grid-template-columns:var(--sidebar) 1fr;min-height:100vh}

/* Sidebar */
.sidebar{background:#fff;border-right:1px solid var(--ink-200);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}
.sidebar__brand{padding:18px 22px;border-bottom:1px solid var(--ink-200)}
.sidebar__brand img{display:block;width:100%;max-width:200px;height:auto}
.sidebar__app-name{margin-top:12px;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-500)}
.sidebar__app-name span{color:var(--nf-red)}

.sidebar__nav{padding:14px 10px;flex:1}
.sidebar__group{margin-bottom:18px}
.sidebar__label{font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-400);padding:0 12px 6px}
.nav-item{display:flex;align-items:center;gap:10px;width:100%;padding:9px 12px;border:0;background:transparent;border-radius:var(--radius-sm);color:var(--ink-700);font-size:13.5px;cursor:pointer;text-align:left;transition:background var(--transition),color var(--transition)}
.nav-item:hover{background:var(--ink-100)}
.nav-item.is-active{background:var(--nf-red-soft);color:var(--nf-red-dark);font-weight:600}
.nav-item.is-active svg{color:var(--nf-red)}
.nav-item svg{width:18px;height:18px;flex-shrink:0;color:var(--ink-500)}
.nav-item .badge-pill{margin-left:auto;background:var(--nf-red);color:#fff;font-size:10.5px;padding:1px 7px;border-radius:99px;font-weight:700}

.sidebar__user{border-top:1px solid var(--ink-200);padding:14px 18px;display:flex;align-items:center;gap:10px}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--nf-red);color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px;flex-shrink:0}
.user-meta{font-size:13px;line-height:1.3;min-width:0;flex:1}
.user-meta strong{display:block;color:var(--ink-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-meta span{color:var(--ink-500);font-size:11.5px}
.user-meta .admin-tag{display:inline-block;background:var(--nf-red);color:#fff;font-size:9.5px;padding:1px 5px;border-radius:3px;margin-left:4px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.logout-btn{background:transparent;border:0;color:var(--ink-500);cursor:pointer;padding:6px;border-radius:var(--radius-sm)}
.logout-btn:hover{background:var(--ink-100);color:var(--nf-red)}

/* Main */
.main{display:flex;flex-direction:column;min-width:0}
.topbar{background:#fff;border-bottom:1px solid var(--ink-200);padding:14px 28px;display:flex;align-items:center;justify-content:space-between;gap:16px;position:sticky;top:0;z-index:10}
.crumbs{font-size:12.5px;color:var(--ink-500);display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.crumbs strong{color:var(--ink-900);font-weight:600}
.crumbs .sep{color:var(--ink-300)}
.topbar__actions{display:flex;align-items:center;gap:8px}

.content{padding:28px;max-width:1280px;width:100%}

/* Page header */
.page-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:22px;gap:16px;flex-wrap:wrap}
.page-head h1{font-size:24px;font-weight:700;margin:0 0 4px;letter-spacing:-.01em}
.page-head p{margin:0;color:var(--ink-500);font-size:13.5px}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:var(--radius-sm);border:1px solid transparent;font-size:13px;font-weight:600;cursor:pointer;transition:all var(--transition);white-space:nowrap;line-height:1.2}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn svg{width:15px;height:15px;flex-shrink:0}
.btn--primary{background:var(--nf-red);color:#fff;border-color:var(--nf-red)}
.btn--primary:hover:not(:disabled){background:var(--nf-red-dark);border-color:var(--nf-red-dark)}
.btn--ghost{background:transparent;color:var(--ink-700);border-color:var(--ink-300)}
.btn--ghost:hover:not(:disabled){background:var(--ink-100);border-color:var(--ink-400)}
.btn--subtle{background:var(--ink-100);color:var(--ink-700);border-color:var(--ink-100)}
.btn--subtle:hover:not(:disabled){background:var(--ink-200)}
.btn--danger{background:#fff;color:var(--nf-red);border-color:var(--nf-red-soft2)}
.btn--danger:hover:not(:disabled){background:var(--nf-red-soft);border-color:var(--nf-red);color:var(--nf-red-dark)}
.btn--sm{padding:5px 10px;font-size:12px}
.btn--icon{padding:7px;width:32px;height:32px;justify-content:center}

/* Cards / Tables */
.card{background:#fff;border:1px solid var(--ink-200);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.card__head{padding:14px 18px;border-bottom:1px solid var(--ink-200);display:flex;align-items:center;justify-content:space-between;gap:12px}
.card__head h2{margin:0;font-size:14.5px;font-weight:600}
.card__body{padding:18px}
.card__body--flush{padding:0}

.table{width:100%;border-collapse:collapse;font-size:13px}
.table th{text-align:left;padding:11px 16px;font-weight:600;color:var(--ink-500);font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;border-bottom:1px solid var(--ink-200);background:var(--ink-50)}
.table td{padding:13px 16px;border-bottom:1px solid var(--ink-200);color:var(--ink-700);vertical-align:middle}
.table tr:last-child td{border-bottom:0}
.table tr.row-link{cursor:pointer;transition:background var(--transition)}
.table tr.row-link:hover{background:var(--ink-50)}
.table .nowrap{white-space:nowrap}
.table .num{text-align:right;font-variant-numeric:tabular-nums}
.table .actions{display:flex;gap:6px;justify-content:flex-end}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:99px;font-size:11.5px;font-weight:600;line-height:1.4;white-space:nowrap}
.badge--draft     {background:var(--ink-100);color:var(--ink-700)}
.badge--review    {background:var(--warn-soft);color:var(--warn)}
.badge--final     {background:var(--ok-soft);color:var(--ok)}
.badge--locked    {background:#EEE9FB;color:#5B3DBE}
.badge--pending   {background:var(--info-soft);color:var(--info)}
.badge--opened    {background:var(--warn-soft);color:var(--warn)}
.badge--submitted {background:var(--ok-soft);color:var(--ok)}
.badge--expired   {background:var(--ink-100);color:var(--ink-500)}
.badge--revoked   {background:var(--nf-red-soft);color:var(--nf-red-dark)}
.badge--dot::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;display:inline-block}

/* Forms */
.field{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.field label{font-size:12.5px;font-weight:600;color:var(--ink-700)}
.field .hint{font-size:11.5px;color:var(--ink-500)}
.input,.select,.textarea{width:100%;padding:9px 11px;border:1px solid var(--ink-300);border-radius:var(--radius-sm);font-size:13.5px;font-family:inherit;color:var(--ink-900);background:#fff;transition:border-color var(--transition), box-shadow var(--transition)}
.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--nf-red);box-shadow:0 0 0 3px var(--nf-red-soft)}
.textarea{min-height:80px;resize:vertical}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
.stat{background:#fff;border:1px solid var(--ink-200);border-radius:var(--radius);padding:16px 18px}
.stat__label{font-size:11.5px;font-weight:600;color:var(--ink-500);text-transform:uppercase;letter-spacing:.06em}
.stat__value{font-size:26px;font-weight:700;margin-top:4px;letter-spacing:-.02em}
.stat__delta{font-size:12px;color:var(--ink-500);margin-top:2px}
.stat__delta strong{color:var(--ok)}

/* Filter bar */
.filterbar{display:flex;gap:10px;align-items:center;margin-bottom:14px;flex-wrap:wrap}
.search{position:relative;flex:1;min-width:240px;max-width:420px}
.search input{padding-left:34px}
.search svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--ink-400);pointer-events:none}

/* Document detail */
.doc-grid{display:grid;grid-template-columns:1fr 320px;gap:22px;align-items:flex-start}
.section-list{display:flex;flex-direction:column;gap:6px;margin:0;padding:0;list-style:none}
.section-list li{padding:11px 14px;border:1px solid var(--ink-200);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:space-between;background:#fff;cursor:pointer;transition:border-color var(--transition), background var(--transition)}
.section-list li:hover{border-color:var(--ink-400);background:var(--ink-50)}
.section-list li.is-active{border-color:var(--nf-red);background:var(--nf-red-soft);color:var(--nf-red-dark)}
.section-list .sec-title{font-weight:600;font-size:13px}
.section-list .sec-meta{font-size:11.5px;color:var(--ink-500)}

/* Tabs */
.tabs{display:flex;gap:2px;border-bottom:1px solid var(--ink-200);margin-bottom:18px}
.tab{padding:10px 16px;border:0;background:transparent;font-size:13px;font-weight:600;color:var(--ink-500);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color var(--transition), border-color var(--transition)}
.tab:hover{color:var(--ink-900)}
.tab.is-active{color:var(--nf-red);border-bottom-color:var(--nf-red)}

/* Hazards */
.hazard{border:1px solid var(--ink-200);border-radius:var(--radius-sm);padding:14px;margin-bottom:10px;background:#fff}
.hazard__head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}
.hazard__title{font-weight:600;font-size:13.5px}
.hazard__meta{font-size:12px;color:var(--ink-500);margin-bottom:8px}
.hazard__actions{display:flex;gap:6px}
.risk-pill{padding:2px 8px;border-radius:99px;font-size:11px;font-weight:700;white-space:nowrap}
.risk-low{background:#E8F4EC;color:#1F7A3A}
.risk-mid{background:#FBEFE0;color:#B8651A}
.risk-high{background:#FCE0E2;color:#B30410}

/* Audit log */
.log{display:flex;flex-direction:column}
.log__entry{display:grid;grid-template-columns:120px 32px 1fr;gap:12px;padding:11px 0;border-bottom:1px solid var(--ink-200);font-size:13px}
.log__entry:last-child{border-bottom:0}
.log__time{color:var(--ink-500);font-size:12px;font-variant-numeric:tabular-nums}
.log__avatar{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:600;font-size:11px;align-self:start;margin-top:2px}
.log__action strong{color:var(--ink-900)}
.log__action .field-name{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;background:var(--ink-100);padding:1px 5px;border-radius:3px;font-size:12px}

/* Modal */
.modal-backdrop{position:fixed;inset:0;background:rgba(28,27,27,.5);display:none;align-items:center;justify-content:center;z-index:100;padding:20px}
.modal-backdrop.is-open{display:flex}
.modal{background:#fff;border-radius:var(--radius);box-shadow:0 20px 60px rgba(0,0,0,.25);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;animation:modalIn 200ms cubic-bezier(.2,.8,.2,1)}
.modal--wide{max-width:720px}
@keyframes modalIn{from{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}
.modal__head{padding:18px 22px;border-bottom:1px solid var(--ink-200);display:flex;align-items:center;justify-content:space-between}
.modal__head h2{margin:0;font-size:16px;font-weight:600}
.modal__body{padding:22px}
.modal__foot{padding:14px 22px;border-top:1px solid var(--ink-200);display:flex;justify-content:flex-end;gap:8px;background:var(--ink-50);border-radius:0 0 var(--radius) var(--radius)}

/* Toast */
.toast{position:fixed;bottom:24px;right:24px;background:var(--ink-900);color:#fff;padding:11px 16px;border-radius:var(--radius-sm);font-size:13px;box-shadow:var(--shadow-md);display:flex;align-items:center;gap:9px;z-index:200;transform:translateY(20px);opacity:0;transition:all 220ms cubic-bezier(.2,.8,.2,1);pointer-events:none;max-width:400px}
.toast.is-show{transform:none;opacity:1}
.toast.is-error{background:var(--nf-red-dark)}
.toast svg{width:16px;height:16px;color:#7DD89F;flex-shrink:0}
.toast.is-error svg{color:#FBC2C5}

/* Empty */
.empty{padding:40px 20px;text-align:center;color:var(--ink-500)}
.empty svg{width:36px;height:36px;color:var(--ink-300);margin-bottom:8px}

/* Share / checklist */
.share-card{background:linear-gradient(180deg,#fff 0%, var(--ink-50) 100%);border:1px dashed var(--ink-300);border-radius:var(--radius);padding:18px}
.checklist{margin:0;padding:0;list-style:none}
.checklist li{display:flex;align-items:flex-start;gap:10px;padding:9px 0;border-bottom:1px solid var(--ink-200);font-size:13px}
.checklist li:last-child{border-bottom:0}
.checklist input[type=checkbox]{width:16px;height:16px;accent-color:var(--nf-red);margin-top:2px;flex-shrink:0;cursor:pointer}
.checklist label{cursor:pointer;flex:1}
.checklist .desc{color:var(--ink-500);font-size:12px;display:block;margin-top:1px}

/* Token display */
.token-box{
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;
  background:var(--ink-100);padding:10px 12px;border-radius:var(--radius-sm);
  font-size:12px;word-break:break-all;border:1px solid var(--ink-200);
  display:flex;align-items:center;gap:8px;justify-content:space-between
}

/* Mobile */
.menu-toggle{display:none;background:transparent;border:0;padding:6px;cursor:pointer;color:var(--ink-700)}
.scrim{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:40;display:none}
.scrim.is-open{display:block}
@media (max-width: 900px){
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed;left:-280px;top:0;height:100vh;width:260px;z-index:50;transition:left var(--transition);box-shadow:var(--shadow-md)}
  .sidebar.is-open{left:0}
  .menu-toggle{display:inline-flex}
  .stats{grid-template-columns:repeat(2,1fr)}
  .doc-grid{grid-template-columns:1fr}
  .content{padding:18px}
  .topbar{padding:12px 16px}
  .field-row,.field-row-3{grid-template-columns:1fr}
  .topbar__actions .btn-text{display:none}
}

/* Status indicator dots inline */
.status-row{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--ink-500)}
.dot{width:8px;height:8px;border-radius:50%;background:var(--ink-400);display:inline-block;flex-shrink:0}
.dot--ok{background:var(--ok)}
.dot--warn{background:var(--warn)}
.dot--err{background:var(--nf-red)}
