:root{--bg:#f5f7fb;--surface:#fff;--surface2:#f8fafc;--text:#0f172a;--muted:#64748b;--border:rgba(15,23,42,.1);--shadow:0 10px 30px rgba(2,6,23,.08);--shadow2:0 6px 18px rgba(2,6,23,.06);--blue:#1d4ed8;--blueSoft:rgba(29,78,216,.1);--fpt-blue:#1d4ed8;--fpt-orange:#f37021;--fpt-green:#00a859}html.dark{--bg:#0b1220;--surface:#0f172a;--surface2:#111c33;--text:#e5e7eb;--muted:#94a3b8;--border:rgba(148,163,184,.18);--shadow:0 12px 34px rgba(0,0,0,.45);--shadow2:0 8px 22px rgba(0,0,0,.35);--blue:#60a5fa;--blueSoft:rgba(96,165,250,.14);--fpt-blue:#60a5fa;--fpt-orange:#ff8a4c;--fpt-green:#36d38a}.input--small{padding:8px 10px;font-size:12px}.folderDot{width:10px;height:10px;border-radius:999px;background:rgba(148,163,184,.6);box-shadow:inset 0 0 0 1px var(--border)}.folderDot--fpt_blue{background:var(--fpt-blue)}.folderDot--fpt_orange{background:var(--fpt-orange)}.folderDot--fpt_green{background:var(--fpt-green)}.folderDot--purple{background:#8b5cf6}.folderDot--gray{background:rgba(148,163,184,.8)}*{box-sizing:border-box}body,html{height:100%}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,Apple Color Emoji,Segoe UI Emoji;color:var(--text);background:var(--bg)}a{color:inherit;text-decoration:none}button,input{font-family:inherit}.pl{display:flex;min-height:100vh}.pl-sidebar{width:290px;background:var(--surface);border-right:1px solid var(--border);position:-webkit-sticky;position:sticky;top:0;height:100vh;overflow:auto}.pl-brand{gap:12px;padding:18px 18px 14px}.pl-brand,.pl-brandLogo{display:flex;align-items:center}.pl-brandLogo{width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,rgba(34,197,94,.22),rgba(29,78,216,.16));border:1px solid var(--border);justify-content:center;font-weight:800}.pl-brandTop{font-size:12px;color:var(--muted);font-weight:700}.pl-brandBottom{font-size:14px;font-weight:900;letter-spacing:.02em;color:#ea580c}.pl-nav{padding:8px 12px 18px}.pl-navTitle{font-size:12px;font-weight:800;color:rgba(100,116,139,.9);padding:6px 10px}.ps-item{width:100%;border:0;background:transparent;cursor:pointer;display:flex;align-items:center;gap:12px;padding:10px;border-radius:14px;color:rgba(15,23,42,.92)}.ps-item:hover{background:rgba(2,6,23,.04)}.ps-item--active{background:var(--blueSoft);color:var(--blue)}.ps-icon{width:36px;height:36px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:rgba(2,6,23,.03);border:1px solid rgba(15,23,42,.08)}.ps-item--active .ps-icon{background:rgba(29,78,216,.12);border-color:rgba(29,78,216,.22)}.ps-label{font-size:14px;font-weight:650}.ps-badge{margin-left:auto;font-size:12px;color:var(--muted)}.pl-main{flex:1 1;min-width:0;display:flex;flex-direction:column}.pl-topbar{height:68px;display:flex;align-items:center;justify-content:space-between;padding:0 18px;border-bottom:1px solid var(--border);background:hsla(0,0%,100%,.88);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:-webkit-sticky;position:sticky;top:0;z-index:20}html.dark .pl-topbar{background:rgba(15,23,42,.72)}.pl-burger{display:none;border:1px solid var(--border);background:var(--surface);border-radius:12px;width:44px;height:44px;align-items:center;justify-content:center;cursor:pointer}.pl-topTitleMain{font-size:16px;font-weight:850}.pl-topTitleSub{font-size:12px;color:var(--muted);margin-top:2px}.pl-topActions{gap:10px}.pl-search,.pl-topActions{display:flex;align-items:center}.pl-search{gap:8px;border:1px solid var(--border);background:var(--surface);border-radius:14px;padding:10px 12px;width:320px}.pl-searchInput{border:0;outline:none;width:100%;font-size:14px}.pl-searchIcon{color:rgba(100,116,139,.95);display:flex}.pl-iconBtn{position:relative;border:1px solid var(--border);background:var(--surface);border-radius:14px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer}.pl-dot{position:absolute;top:10px;right:10px;width:8px;height:8px;border-radius:999px;background:#ef4444}.pl-user{gap:10px;padding-left:6px}.pl-avatar,.pl-user{display:flex;align-items:center}.pl-avatar{width:40px;height:40px;border-radius:999px;background:linear-gradient(135deg,rgba(29,78,216,.18),rgba(34,197,94,.14));border:1px solid var(--border);justify-content:center;font-weight:800}.pl-userHi{font-weight:800;font-size:13px}.pl-userEmail{font-size:12px;color:var(--muted);max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pl-content{padding:18px}.pl-backdrop{display:none}@media (max-width:1024px){.pl-search{display:none}}@media (max-width:860px){.pl-burger{display:inline-flex}.pl-sidebar{position:fixed;left:-320px;top:0;z-index:50;box-shadow:var(--shadow);transition:left .2s ease}.pl-sidebar--open{left:0}.pl-backdrop{display:block;position:fixed;inset:0;background:rgba(2,6,23,.35);z-index:40}}.card{background:var(--surface);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow2);padding:14px}.title{font-weight:900;font-size:16px}.grid{display:grid;grid-template-columns:1.3fr .7fr;grid-gap:16px;gap:16px}@media (max-width:1100px){.grid{grid-template-columns:1fr}}.toolbar{display:flex;gap:10px;align-items:center;justify-content:space-between;margin-bottom:12px}.input{width:100%;border:1px solid var(--border);border-radius:14px;outline:none;background:var(--surface);font-size:14px}.btn,.input{padding:10px 12px}.btn{border:1px solid rgba(29,78,216,.22);background:rgba(29,78,216,.1);color:var(--blue);border-radius:14px;font-weight:750;cursor:pointer;display:inline-flex;align-items:center;gap:8px}.btn:hover{background:rgba(29,78,216,.14)}.btnGhost{border:1px solid var(--border);background:var(--surface);border-radius:14px;padding:10px 12px;cursor:pointer;font-weight:750}.muted{color:var(--muted)}.small{font-size:12px}.table{width:100%;border-collapse:collapse}.table td,.table th{text-align:left;padding:10px 8px;border-bottom:1px solid rgba(15,23,42,.08);font-size:14px}.table th{font-size:12px;color:rgba(100,116,139,.95);text-transform:uppercase;letter-spacing:.06em}.pill{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;border:1px solid rgba(15,23,42,.1);background:rgba(2,6,23,.02);font-size:12px;color:var(--muted)}.linkBtn{border:0;background:transparent;padding:0;color:var(--blue);cursor:pointer;font-weight:750}.linkBtn:hover{text-decoration:underline}.alert{border:1px solid rgba(239,68,68,.25);background:rgba(239,68,68,.06);color:#b91c1c;padding:10px 12px;border-radius:14px;margin-bottom:12px}.page{padding:18px}.grid2{display:grid;grid-template-columns:1fr 360px;grid-gap:16px;gap:16px;align-items:start}.formGrid{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px}@media (max-width:1100px){.formGrid{grid-template-columns:1fr}}.formLabel{display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--muted);font-weight:800}.modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:1000}.modalBackdrop{position:absolute;inset:0;background:rgba(2,6,23,.55)}.modalCard{position:relative;width:min(780px,calc(100vw - 24px));max-height:calc(100vh - 24px);overflow:auto;background:var(--surface);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow);padding:14px}.modalHeader{justify-content:space-between;gap:12px;border-bottom:1px solid var(--border);padding-bottom:10px}.crumbs,.modalHeader{display:flex;align-items:center}.crumbs{flex-wrap:wrap;gap:6px}.crumb{display:inline-flex;gap:6px;align-items:center}.crumbSep{color:rgba(100,116,139,.75)}.crumbBtn{border:1px solid rgba(15,23,42,.1);background:rgba(2,6,23,.02);padding:6px 10px;border-radius:999px;cursor:pointer;font-weight:800;color:rgba(15,23,42,.85)}.crumbBtn:hover{background:rgba(2,6,23,.04)}.crumbBtn--active{background:var(--blueSoft);color:var(--blue);border-color:rgba(29,78,216,.22)}@media (max-width:1100px){.grid2{grid-template-columns:1fr}}.treeWrap{border:1px solid var(--border);border-radius:14px;padding:10px;background:var(--card)}.treeRow{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px;border-radius:10px}.treeRow:hover{background:var(--hover)}.treeRow--into{background:rgba(0,132,255,.12);outline:1px solid rgba(0,132,255,.45)}.treeRow--before{position:relative}.treeRow--before:before{content:"";position:absolute;left:8px;right:8px;top:0;height:2px;background:rgba(0,132,255,.85);border-radius:2px}.treeRow--after{position:relative}.treeRow--after:after{content:"";position:absolute;left:8px;right:8px;bottom:0;height:2px;background:rgba(0,132,255,.85);border-radius:2px}.treeRowOverlay{background:var(--card);border:1px solid var(--accent);box-shadow:0 10px 30px rgba(0,0,0,.18)}.treeNameOverlay{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.treeRowLeft{gap:10px;flex:1 1;min-width:0}.treeRowLeft,.treeRowRight{display:flex;align-items:center}.treeRowRight{gap:8px}.dragHandle{cursor:-webkit-grab;cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none;color:var(--muted);font-weight:900;padding:2px 6px;border-radius:8px}.dragHandle:hover{background:var(--hover)}.treeName{flex:1 1;min-width:0;border:1px solid transparent;background:transparent;color:var(--text);font-weight:800;padding:6px 8px;border-radius:10px}.treeName:focus{outline:none;border-color:rgba(29,78,216,.25);background:var(--blueSoft)}.btnMini{border:1px solid var(--border);background:var(--card);color:var(--text);padding:6px 10px;border-radius:10px;font-weight:800;cursor:pointer}.btnMini:hover{background:var(--hover)}.btnMiniDanger{border:1px solid rgba(220,38,38,.25);background:rgba(220,38,38,.06);color:rgba(220,38,38,.95);padding:6px 10px;border-radius:10px;font-weight:900;cursor:pointer}.btnMiniDanger:hover{background:rgba(220,38,38,.1)}