@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=JetBrains+Mono:wght@400;500&display=swap');
:root,[data-theme="light"]{--bg:#f5f5f0;--surface:#fff;--surface2:#f0efe8;--surface3:#e8e7e0;--border:#ddd9d0;--border-light:#ccc8bf;--text:#1a1a1a;--text-dim:#5c5c5c;--text-muted:#8c8c8c;--accent:#2563eb;--accent-bg:#eff4ff;--accent-border:#bfdbfe;--green:#16a34a;--green-bg:#ecfdf5;--green-border:#bbf7d0;--orange:#c2410c;--orange-bg:#fff7ed;--orange-border:#fed7aa;--red:#dc2626;--red-bg:#fef2f2;--purple:#7c3aed;--purple-bg:#f5f3ff;--purple-border:#ddd6fe;--cyan:#0891b2;--cyan-bg:#ecfeff;--shadow:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);--shadow-lg:0 4px 12px rgba(0,0,0,.08);}
[data-theme="dark"]{--bg:#0e1117;--surface:#161b22;--surface2:#1c2333;--surface3:#242c3a;--border:#2d333b;--border-light:#3d444d;--text:#e6edf3;--text-dim:#9ca3af;--text-muted:#656d76;--accent:#58a6ff;--accent-bg:#152238;--accent-border:#1f3a5f;--green:#3fb950;--green-bg:#122117;--green-border:#1a3a2a;--orange:#e09b3d;--orange-bg:#261c08;--orange-border:#3d2e0a;--red:#f85149;--red-bg:#220e0e;--purple:#bc8cff;--purple-bg:#1c1532;--purple-border:#2d1f4e;--cyan:#39d2c0;--cyan-bg:#0c1f1e;--shadow:0 1px 3px rgba(0,0,0,.2),0 1px 2px rgba(0,0,0,.15);--shadow-lg:0 4px 12px rgba(0,0,0,.3);}
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'DM Sans',-apple-system,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;font-size:14px;line-height:1.5;}
.app{display:grid;grid-template-columns:var(--sidebar-w,360px) 1fr;grid-template-rows:auto 1fr;height:100vh;}
header{grid-column:1/-1;background:var(--surface);border-bottom:1px solid var(--border);padding:10px 20px;display:flex;align-items:center;gap:6px;}
.hdr-sep{width:1px;height:22px;background:var(--border);margin:0 4px;flex-shrink:0;}
.customer-switcher{font-size:12px;padding:4px 28px 4px 10px;border-radius:7px;border:1px solid var(--border);background:var(--surface2);color:var(--text);cursor:pointer;max-width:220px;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23888'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.customer-switcher:focus{outline:none;border-color:var(--accent);}
.logo{display:flex;align-items:center;gap:10px;}.logo-icon{height:36px;display:flex;align-items:center;}.logo-icon img{height:100%;width:auto;}.logo-light{display:block!important;}.logo-dark{display:none!important;}[data-theme="light"] .logo-light{display:block!important;}[data-theme="light"] .logo-dark{display:none!important;}[data-theme="dark"] .logo-light{display:none!important;}[data-theme="dark"] .logo-dark{display:block!important;}
header h1{font-size:16px;font-weight:700;letter-spacing:-.4px;}header .subtitle{font-size:11px;color:var(--text-muted);margin-top:-2px;}
.stats-bar{display:flex;gap:12px;margin-left:auto;}.stat{text-align:center;padding:3px 10px;background:var(--surface2);border-radius:7px;}.stat-val{font-size:16px;font-weight:700;font-family:'JetBrains Mono',monospace;}.stat-label{font-size:9px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:500;}
.build-nr{font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--text);background:var(--surface2);padding:2px 8px;border-radius:5px;white-space:nowrap;letter-spacing:.3px;border:1px solid var(--border);flex-shrink:0;opacity:.7;cursor:default;}
.hdr-btn{width:34px;height:34px;border-radius:9px;border:1px solid var(--border);background:var(--surface2);color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .2s;flex-shrink:0;}.hdr-btn:hover{border-color:var(--accent);background:var(--accent-bg);}
.sidebar{background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;position:relative;}.sidebar-resize{position:absolute;top:0;right:-3px;width:6px;height:100%;cursor:col-resize;z-index:10;}.sidebar-resize:hover,.sidebar-resize.dragging{background:var(--accent);opacity:.3;}
.search-box{padding:10px 14px;border-bottom:1px solid var(--border);}.search-box input{width:100%;padding:8px 12px 8px 32px;background:var(--surface2);border:1px solid var(--border);border-radius:7px;color:var(--text);font-size:13px;font-family:'DM Sans',sans-serif;outline:none;transition:all .2s;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='15' height='15' viewBox='0 0 24 24' fill='none' stroke='%238c8c8c' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.3-4.3'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:9px center;}.search-box input:focus{border-color:var(--accent);background-color:var(--surface);box-shadow:0 0 0 3px var(--accent-bg);}.search-box input::placeholder{color:var(--text-muted);}
.view-switch{display:flex;padding:6px 14px;gap:3px;border-bottom:1px solid var(--border);}.vs-btn{flex:1;padding:5px 6px;border-radius:6px;font-size:11px;cursor:pointer;background:transparent;color:var(--text-dim);border:none;font-family:'DM Sans',sans-serif;font-weight:500;transition:all .15s;text-align:center;}.vs-btn:hover{background:var(--surface2);}.vs-btn.active{background:var(--accent);color:#fff;}
.sidebar-toolbar{display:flex;align-items:center;gap:5px;padding:5px 14px;border-bottom:1px solid var(--border);}.stb-btn{padding:2px 8px;border-radius:4px;border:1px solid var(--border);background:var(--surface2);color:var(--text-dim);cursor:pointer;font-family:'DM Sans',sans-serif;font-size:10.5px;transition:all .15s;white-space:nowrap;}.stb-btn:hover{border-color:var(--accent);color:var(--accent);}.stb-btn.toggled{background:var(--accent-bg);border-color:var(--accent);color:var(--accent);}.stb-spacer{flex:1;}
.sidebar-scroll{flex:1;overflow-y:auto;padding:2px 0;}.sidebar-scroll::-webkit-scrollbar{width:5px;}.sidebar-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px;}
.bereich-section{margin-bottom:1px;}.bereich-header{display:flex;align-items:center;gap:7px;padding:9px 14px 5px;cursor:pointer;user-select:none;position:sticky;top:0;background:var(--surface);z-index:2;}.bereich-header:hover{background:var(--surface2);}.bereich-icon{font-size:15px;}.bereich-label{font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;flex:1;}.bereich-count{font-size:9.5px;color:var(--text-muted);font-family:'JetBrains Mono',monospace;background:var(--surface2);padding:1px 5px;border-radius:9px;}.bereich-chevron{font-size:9px;color:var(--text-muted);transition:transform .2s;}.bereich-section.collapsed .bereich-chevron{transform:rotate(-90deg);}.bereich-section.collapsed .bereich-content{display:none;}
.group-section{margin-bottom:1px;}.group-header{padding:6px 14px 3px 30px;font-size:11px;font-weight:600;color:var(--text-dim);letter-spacing:.2px;cursor:pointer;display:flex;align-items:center;gap:5px;user-select:none;transition:background .1s;}.group-header:hover{background:var(--surface2);}.group-chevron{font-size:8px;color:var(--text-muted);transition:transform .15s;}.group-section.g-collapsed .group-chevron{transform:rotate(-90deg);}.group-section.g-collapsed .group-roles{display:none;}.group-count{font-size:9.5px;color:var(--text-muted);font-family:'JetBrains Mono',monospace;margin-left:auto;}
.role-item{padding:3px 14px 3px 44px;cursor:pointer;display:flex;align-items:center;gap:6px;border-left:3px solid transparent;transition:all .1s;}.role-item.role-ungrouped{padding-left:30px;}.role-item:hover{background:var(--surface2);}.role-item.selected{background:var(--accent-bg);border-left-color:var(--accent);}.role-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;}.dot-sammel{background:var(--purple);}.dot-rolle{background:var(--cyan);}.dot-inactive{background:var(--border);}.role-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px;}.role-label-dim{color:var(--text-muted);}.role-label-haupt{font-weight:600;}.role-label-neben{font-weight:400;font-style:italic;}.rtb{font-size:7.5px;padding:1px 3px;border-radius:3px;font-weight:700;flex-shrink:0;text-transform:uppercase;letter-spacing:.3px;}.rtb-1{background:var(--accent-bg);color:var(--accent);}.rtb-2{background:var(--surface3);color:var(--text-muted);}.rtb-s{background:#7c3aed22;color:#7c3aed;}.role-users-count{font-size:9.5px;color:var(--text-muted);font-family:'JetBrains Mono',monospace;flex-shrink:0;}
.user-item{padding:5px 14px;cursor:pointer;display:flex;align-items:center;gap:9px;transition:all .1s;border-left:3px solid transparent;}.user-item:hover{background:var(--surface2);}.user-item.selected{background:var(--accent-bg);border-left-color:var(--accent);}.user-avatar-sm{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:600;color:#fff;flex-shrink:0;}.user-item-name{font-size:12px;font-weight:500;flex:1;}.user-item-sub{font-size:10px;color:var(--text-muted);}
.tg-item{padding:5px 14px 5px 34px;cursor:pointer;display:flex;align-items:center;gap:7px;transition:all .1s;border-left:3px solid transparent;}.tg-item:hover{background:var(--surface2);}.tg-item.selected{background:var(--accent-bg);border-left-color:var(--accent);}.tg-icon{font-size:13px;flex-shrink:0;}.tg-label{font-size:12px;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}.tg-mail{font-size:10px;color:var(--text-muted);flex-shrink:0;}
.hide-inherited .folder-inherited{display:none !important}
/* Folder items in sidebar */
.folder-item{padding:4px 14px;cursor:pointer;display:flex;align-items:center;gap:5px;border-left:3px solid transparent;transition:all .1s;font-size:11.5px;}.folder-item:hover{background:var(--surface2);}.folder-item.selected{background:var(--accent-bg);border-left-color:var(--accent);}.folder-icon{flex-shrink:0;font-size:13px;}.folder-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}.folder-perm-count{font-size:9px;color:var(--text-muted);font-family:'JetBrains Mono',monospace;}
.trm-col{display:inline-flex;gap:1px;flex-shrink:0;width:48px;min-width:48px;}.trm-cell{font-size:8px;width:14px;text-align:center;padding:0 1px;border-radius:2px;font-weight:700;font-family:'JetBrains Mono',monospace;color:var(--border);}
.legend{display:flex;gap:14px;padding:6px 14px;border-bottom:1px solid var(--border);font-size:10px;color:var(--text-muted);}.legend-item{display:flex;align-items:center;gap:3px;}.legend-dot{width:5px;height:5px;border-radius:50%;}
.main{overflow-y:auto;padding:10px 32px;background:var(--bg);}.main::-webkit-scrollbar{width:6px;}.main::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px;}
.welcome{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;max-width:400px;margin:0 auto;}.welcome-icon{width:64px;height:64px;border-radius:18px;margin-bottom:16px;background:var(--surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:28px;}.welcome h2{font-size:17px;font-weight:600;margin-bottom:6px;}.welcome p{font-size:13px;color:var(--text-dim);line-height:1.6;}
.detail-header{margin-bottom:0;position:sticky;top:-10px;z-index:10;background:var(--bg);padding:10px 0 10px;border-bottom:1px solid var(--border);margin-top:-10px;}.detail-header h2{font-size:20px;font-weight:700;letter-spacing:-.4px;margin-bottom:2px;line-height:1.2;}.detail-subtitle{font-size:12px;color:var(--text-dim);margin-bottom:6px;}.detail-badges{display:flex;gap:6px;align-items:center;flex-wrap:wrap;}
.detail-body{padding-top:12px;}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px;}
@media(max-width:1100px){.detail-grid{grid-template-columns:1fr;}}
.detail-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:14px 16px;box-shadow:var(--shadow);}
.detail-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}.detail-card-title{font-size:12px;font-weight:600;display:flex;align-items:center;gap:6px;}.detail-card-count{font-size:10px;color:var(--text-muted);font-family:'JetBrains Mono',monospace;background:var(--surface2);padding:1px 6px;border-radius:8px;}
.detail-card-full{grid-column:1/-1;}
.badge{display:inline-flex;align-items:center;gap:3px;font-size:10.5px;padding:2px 9px;border-radius:18px;font-weight:500;}.badge-purple{background:var(--purple-bg);color:var(--purple);}.badge-cyan{background:var(--cyan-bg);color:var(--cyan);}.badge-green{background:var(--green-bg);color:var(--green);}.badge-red{background:var(--red-bg);color:var(--red);}.badge-orange{background:var(--orange-bg);color:var(--orange);}.badge-blue{background:var(--accent-bg);color:var(--accent);}
.section{margin-bottom:22px;}.section-header{display:flex;align-items:center;gap:7px;margin-bottom:10px;}.section-title{font-size:12.5px;font-weight:600;}.section-count{font-size:10.5px;color:var(--text-muted);font-family:'JetBrains Mono',monospace;}.section-line{flex:1;height:1px;background:var(--border);margin-left:6px;}
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:7px;}.card{background:var(--surface);border:1px solid var(--border);border-radius:7px;padding:10px 12px;transition:all .15s;cursor:default;box-shadow:var(--shadow);}.card:hover{box-shadow:var(--shadow-lg);}.card-click{cursor:pointer;}.card-click:hover{border-color:var(--accent);}.card-title{font-size:12.5px;font-weight:600;margin-bottom:1px;}.card-sub{font-size:11px;color:var(--text-dim);}
.user-card{display:flex;align-items:center;gap:9px;}.user-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:#fff;flex-shrink:0;}.user-info{flex:1;min-width:0;}.user-name{font-size:12.5px;font-weight:500;}.user-detail{font-size:10.5px;color:var(--text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.tags{display:flex;flex-wrap:wrap;gap:4px;}.tag{display:inline-flex;align-items:center;gap:2px;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500;transition:all .1s;}.tag-direct{background:var(--green-bg);color:var(--green);border:1px solid var(--green-border);}.tag-indirect{background:var(--orange-bg);color:var(--orange);border:1px solid var(--orange-border);}.tag-sammel{background:var(--purple-bg);color:var(--purple);border:1px solid var(--purple-border);}.tag-blue{background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-border);}.tag-click{cursor:pointer;}.tag-click:hover{filter:brightness(.95);transform:translateY(-1px);}.tag-haupt{font-weight:700;}.tag-neben{font-weight:400;font-style:italic;opacity:.85;}
.diff-new{display:inline-flex;align-items:center;gap:3px;padding:3px 9px;border-radius:4px;font-size:11px;font-weight:600;margin:2px;background:#dcfce7;color:#15803d;border:1px solid #86efac;}[data-theme="dark"] .diff-new{background:#14532d;color:#4ade80;border:1px solid #166534;}.diff-existing{display:inline-flex;padding:3px 9px;border-radius:4px;font-size:11px;margin:2px;background:var(--surface2);color:var(--text-muted);border:1px solid var(--border);opacity:.6;}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px;}@media(max-width:1100px){.two-col{grid-template-columns:1fr;}}
.folder-row-traverse{background:var(--accent-bg);border-left-color:var(--accent)!important;}.folder-row-traverse .folder-name{color:var(--accent)!important;font-weight:600;}.folder-row-read{background:var(--green-bg);border-left-color:var(--green)!important;}.folder-row-read .folder-name{color:var(--green)!important;font-weight:700;}.folder-row-modify{background:var(--orange-bg);border-left-color:var(--orange)!important;}.folder-row-modify .folder-name{color:var(--orange)!important;font-weight:700;}@media(max-width:800px){.app{grid-template-columns:1fr;}.sidebar{max-height:40vh;}.stats-bar{display:none;}}
.role-detail-cols{display:grid;grid-template-columns:1fr minmax(30%,1fr);gap:0;min-height:200px;position:relative;}.role-detail-cols>.role-col-left{border-right:1px solid var(--border);padding-right:20px;min-width:0;overflow:hidden;}.role-detail-cols>.role-col-right{padding-left:20px;min-width:0;}.role-col-resize{position:absolute;top:0;width:6px;height:100%;cursor:col-resize;z-index:5;}.role-col-resize:hover,.role-col-resize.dragging{background:var(--accent);opacity:.3;}@media(max-width:1100px){.role-detail-cols{grid-template-columns:1fr;}.role-detail-cols>.role-col-left{border-right:none;padding-right:0;border-bottom:1px solid var(--border);padding-bottom:16px;margin-bottom:16px;}.role-detail-cols>.role-col-right{padding-left:0;}.role-col-resize{display:none;}}
.compact-table{width:100%;border-collapse:collapse;font-size:12px;}.compact-table th{text-align:left;padding:4px 6px;font-weight:600;font-size:10.5px;color:var(--text-muted);border-bottom:1px solid var(--border);}.compact-table td{padding:5px 6px;border-bottom:1px solid var(--surface3);vertical-align:middle;}.compact-table tr:last-child td{border-bottom:none;}.compact-table tbody tr:hover{background:var(--surface2);cursor:pointer;}.compact-table .ct-avatar{width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:8px;font-weight:600;color:#fff;flex-shrink:0;vertical-align:middle;margin-right:6px;}.compact-table .ct-via{font-size:10px;padding:1px 6px;border-radius:8px;background:var(--purple-bg);color:var(--purple);}
.empty{color:var(--text-muted);font-size:11.5px;font-style:italic;padding:6px 0;}.breadcrumb{font-size:11.5px;color:var(--text-muted);margin-bottom:8px;display:flex;align-items:center;gap:5px;}.breadcrumb a{color:var(--accent);text-decoration:none;cursor:pointer;font-weight:500;}.breadcrumb a:hover{text-decoration:underline;}
.role-group-label{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin:8px 0 5px;padding-bottom:3px;border-bottom:1px solid var(--border);}.role-group-label:first-child{margin-top:0;}
.detail-tabs{display:flex;gap:3px;margin-bottom:22px;border-bottom:2px solid var(--border);padding-bottom:0;}.dt-btn{padding:8px 14px;border:none;background:none;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:500;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s;}.dt-btn:hover{color:var(--text);}.dt-btn.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600;}
.bp-table{width:100%;border-collapse:collapse;font-size:12px;}.bp-table th{text-align:left;padding:6px 10px;background:var(--surface2);border-bottom:1px solid var(--border);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--text-muted);}.bp-table td{padding:5px 10px;border-bottom:1px solid var(--border);vertical-align:top;}.bp-table tr:hover td{background:var(--surface2);}.bp-cat{font-size:10px;padding:2px 7px;border-radius:3px;font-weight:600;}.bp-app{background:var(--cyan-bg);color:var(--cyan);}.bp-vtl{background:var(--accent-bg);color:var(--accent);}.bp-mbx{background:var(--orange-bg);color:var(--orange);}.bp-folder{background:var(--purple-bg);color:var(--purple);}.bp-via{font-size:10.5px;color:var(--text-muted);}.bp-type{font-size:10px;padding:1px 5px;border-radius:3px;}.bp-d{background:var(--green-bg);color:var(--green);}.bp-i{background:var(--orange-bg);color:var(--orange);}
.diff-panel{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:16px;margin-bottom:20px;}.diff-select{padding:7px 10px;border:1px solid var(--border);border-radius:6px;background:var(--surface2);color:var(--text);font-family:'DM Sans',sans-serif;font-size:12.5px;min-width:260px;max-width:100%;outline:none;}.diff-select:focus{border-color:var(--accent);}
.audit-entry{display:flex;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);font-size:12px;align-items:flex-start;}.audit-time{font-family:'JetBrains Mono',monospace;font-size:10.5px;color:var(--text-muted);flex-shrink:0;min-width:130px;}.audit-icon{font-size:14px;flex-shrink:0;}.audit-text{flex:1;}
.export-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:7px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-family:'DM Sans',sans-serif;font-size:12.5px;font-weight:500;cursor:pointer;transition:all .15s;}.export-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-bg);}
/* Folder detail */
.perm-level{font-size:10px;padding:2px 7px;border-radius:3px;font-weight:600;}
.pl-read{background:var(--green-bg);color:var(--green);}.pl-modify{background:var(--orange-bg);color:var(--orange);}.pl-list{background:var(--accent-bg);color:var(--accent);}.pl-unknown{background:var(--surface2);color:var(--text-muted);}
.folder-path{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text-muted);word-break:break-all;}
.folder-tree-item{padding:3px 0;display:flex;align-items:center;gap:6px;font-size:12px;}
/* Folder tree row colors */
.ft-row{display:flex;align-items:center;gap:0;padding:2px 0;border-radius:5px;margin:1px 0;transition:all .1s;}
.ft-row:hover{filter:brightness(.96);}
.ft-row-modify{background:var(--orange-bg);border-left:4px solid var(--orange);}
.ft-row-read{background:var(--green-bg);border-left:4px solid var(--green);}
.ft-row-list{background:var(--accent-bg);border-left:4px solid var(--accent);}
.ft-row-none{background:var(--surface);border-left:4px solid var(--border);}
.ft-row-modify .ft-label{color:var(--orange);font-weight:700;}
.ft-row-read .ft-label{color:var(--green);font-weight:700;}
.ft-row-list .ft-label{color:var(--accent);font-weight:600;}
.ft-row-none .ft-label{color:var(--text-dim);font-weight:400;}
.ft-badge{font-size:9px;padding:1px 6px;border-radius:3px;font-weight:700;white-space:nowrap;}
.ft-badge-modify{background:var(--orange);color:#fff;}
.ft-badge-read{background:var(--green);color:#fff;}
.ft-badge-list{background:var(--accent);color:#fff;}
.ft-toggle{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:5px;border:1px solid var(--border);background:var(--surface2);color:var(--text-dim);cursor:pointer;font-family:'DM Sans',sans-serif;font-size:11px;font-weight:500;transition:all .15s;margin-left:auto;}
.ft-toggle:hover{border-color:var(--accent);color:var(--accent);}
.ft-toggle.active{background:var(--accent-bg);border-color:var(--accent);color:var(--accent);}
/* Clickable filter badges */
.ft-filter{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:6px;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;border:2px solid transparent;user-select:none;}
.ft-filter:hover{transform:scale(1.05);}
.ft-filter-modify{background:var(--orange-bg);color:var(--orange);border-color:var(--orange);}
.ft-filter-modify.off{background:var(--surface2);color:var(--text-muted);border-color:var(--border);opacity:.5;}
.ft-filter-read{background:var(--green-bg);color:var(--green);border-color:var(--green);}
.ft-filter-read.off{background:var(--surface2);color:var(--text-muted);border-color:var(--border);opacity:.5;}
.ft-filter-list{background:var(--accent-bg);color:var(--accent);border-color:var(--accent);}
.ft-filter-list.off{background:var(--surface2);color:var(--text-muted);border-color:var(--border);opacity:.5;}


/* Editor mode */
.edit-mode header{border-bottom-color:var(--orange);box-shadow:0 2px 0 var(--orange)}
.edit-toggle{width:auto !important;padding:0 12px !important;gap:5px;font-size:13px}
.edit-toggle.active{background:var(--orange-bg) !important;border-color:var(--orange) !important;color:var(--orange)}
.ed-bar{display:none;align-items:center;gap:6px;margin-left:6px}
.edit-mode .ed-bar{display:flex}
.ed-btn{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;border-radius:6px;border:1px solid var(--border);background:var(--surface);color:var(--text-dim);font-family:'DM Sans',sans-serif;font-size:11.5px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}
.ed-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}
.ed-btn-danger{color:var(--red)}.ed-btn-danger:hover{border-color:var(--red);background:var(--red-bg);color:var(--red)}
.ed-btn-add{background:var(--accent);color:#fff;border-color:var(--accent)}.ed-btn-add:hover{filter:brightness(1.1)}
.modal-overlay{display:none;position:fixed;inset:0;z-index:9000;background:rgba(0,0,0,.4);align-items:center;justify-content:center;backdrop-filter:blur(2px)}
.modal-overlay.open{display:flex}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-lg);width:92%;max-width:700px;max-height:88vh;display:flex;flex-direction:column;overflow:hidden}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}
.modal-header h3{font-size:16px;font-weight:700;letter-spacing:-.3px}
.modal-close{width:30px;height:30px;border-radius:6px;border:none;background:var(--surface2);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.modal-close:hover{background:var(--red-bg);color:var(--red)}
.modal-body{padding:20px;overflow-y:auto;flex:1}
.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:14px 20px;border-top:1px solid var(--border)}
.fm-group{margin-bottom:16px}
.fm-label{display:block;font-size:11.5px;font-weight:600;color:var(--text-dim);margin-bottom:4px;text-transform:uppercase;letter-spacing:.3px}
.fm-input{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:7px;background:var(--surface2);color:var(--text);font-family:'DM Sans',sans-serif;font-size:13px;outline:none;transition:border-color .15s;box-sizing:border-box}.fm-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}
.fm-select{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:7px;background:var(--surface2);color:var(--text);font-family:'DM Sans',sans-serif;font-size:13px;outline:none;box-sizing:border-box}
.fm-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fm-check-list{max-height:180px;overflow-y:auto;border:1px solid var(--border);border-radius:7px;padding:4px;background:var(--surface2)}
.fm-check-list::-webkit-scrollbar{width:4px}.fm-check-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}
.fm-check-item{display:flex;align-items:center;gap:7px;padding:4px 6px;border-radius:4px;font-size:12px;cursor:pointer;transition:background .1s}.fm-check-item:hover{background:var(--surface3)}
.fm-check-item input{accent-color:var(--accent);cursor:pointer;flex-shrink:0}
.fm-search{width:100%;padding:6px 10px;border:1px solid var(--border);border-radius:5px;background:var(--surface);color:var(--text);font-family:'DM Sans',sans-serif;font-size:12px;outline:none;margin-bottom:6px;box-sizing:border-box}.fm-search:focus{border-color:var(--accent)}
.fm-section{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding:8px 6px 4px;border-bottom:1px solid var(--border);margin-bottom:2px}

/* Import overlay */
#importOverlay code{font-size:11px}
#dropZone:hover{border-color:var(--accent) !important;box-shadow:var(--shadow-lg)}
.import-file-tag{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;background:var(--green-bg);color:var(--green);border:1px solid var(--green-border);border-radius:6px;font-size:11px;font-weight:500;margin:3px}
.import-file-tag.pending{background:var(--surface2);color:var(--text-muted);border-color:var(--border)}
.import-progress{width:100%;height:3px;background:var(--surface2);border-radius:2px;overflow:hidden;margin-top:12px}
.import-progress-bar{height:100%;background:linear-gradient(90deg,#2563eb,#7c3aed);border-radius:2px;transition:width .3s;width:0%}


/* Supabase styles */
.trash-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:7px;border:1px solid var(--border);margin-bottom:6px;background:var(--surface);}
.trash-item-info{flex:1;min-width:0;}.trash-item-name{font-size:12.5px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}.trash-item-meta{font-size:10.5px;color:var(--text-muted);}
.trash-btn{padding:4px 10px;border-radius:5px;border:1px solid var(--border);background:var(--surface2);color:var(--text-dim);cursor:pointer;font-size:11px;font-family:'DM Sans',sans-serif;font-weight:500;transition:all .15s;white-space:nowrap;}
.trash-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-bg);}
.trash-btn-danger{border-color:var(--red);color:var(--red)!important;background:var(--red-bg)!important;}
.trash-btn-danger:hover{filter:brightness(.9);}

.sb-input{width:100%;padding:7px 10px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);font-size:12px;font-family:'DM Sans',sans-serif;outline:none;box-sizing:border-box;margin-bottom:6px;transition:all .2s;}
.sb-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg);}
.sb-dataset-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:6px;cursor:pointer;transition:all .1s;border:1px solid transparent;margin-bottom:3px;}
.sb-dataset-item:hover{background:var(--surface2);border-color:var(--border);}
.sb-btn-sm{padding:5px 12px;border-radius:6px;border:1px solid var(--border);background:var(--surface2);color:var(--text-dim);cursor:pointer;font-family:'DM Sans',sans-serif;font-size:11.5px;font-weight:500;transition:all .15s;}
.sb-btn-sm:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-bg);}
.sb-btn-primary{background:var(--accent)!important;color:#fff!important;border-color:var(--accent)!important;}
.sb-btn-primary:hover{filter:brightness(1.1);}
