:root{color:#171717;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;--accent:#171717;--accent-strong:#000;--accent-soft:#f1ecff;--accent-soft-strong:#e6dcff;--border:#deded8;--panel:#fff;--panel-muted:#f8f8f5;--muted:#676a6f;--ink:#171717;--danger:#a31632;--danger-soft:#fff0f2;--warning:#8a5b10;--warning-soft:#fff6d8;--success:#146a43;--success-soft:#e7f7ee;--pastel-lime:#d9f99d;--pastel-lilac:#ede5ff;--pastel-mint:#ddf7eb;--pastel-pink:#ffe2ea;--shadow:0 18px 48px #17171714;--floating-shadow:0 24px 80px #1717172e;background:#f7f7f4;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{background:var(--panel-muted);min-width:320px;min-height:100vh;margin:0}button,input,select,textarea{font:inherit}button{cursor:pointer;transition:background-color .16s,border-color .16s,color .16s,transform .16s}button:disabled{cursor:not-allowed;opacity:.58}:focus-visible{outline:2px solid var(--accent-strong);outline-offset:2px}.spin{animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-screen,.full-screen-state{background:linear-gradient(135deg, #ede5ff8f 0 38%, transparent 38%), linear-gradient(315deg, #ddf7ebb3 0 32%, transparent 32%), var(--panel);place-items:center;min-height:100vh;padding:24px;display:grid}.full-screen-state{color:var(--muted);align-content:center;gap:16px}.full-screen-state h1{color:var(--ink);margin:0;font-size:20px;font-weight:700}.login-panel{border:1px solid var(--border);background:var(--panel);width:min(100%,380px);box-shadow:var(--floating-shadow);border-radius:8px;gap:18px;padding:30px;display:grid}.brand-mark{color:#fff;background:var(--accent);border-radius:8px;place-items:center;width:42px;height:42px;display:inline-grid}.brand-mark.small{border-radius:7px;width:34px;height:34px}.login-panel h1{letter-spacing:0;margin:0;font-size:26px;font-weight:800;line-height:1.1}.login-panel label{gap:8px;display:grid}.login-panel label span{color:var(--muted);font-size:13px}.login-panel input,.toolbar input,.toolbar select{border:1px solid var(--border);width:100%;min-height:40px;color:var(--ink);background:#fff;border-radius:8px;outline:none}.login-panel input{padding:0 12px}.login-panel input:focus,.toolbar input:focus,.toolbar select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #ede5fff2}.primary-button,.logout-button,.icon-text-button,.wide-action,.row-action,.search-form button,.icon-button{border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;gap:8px;min-height:38px;padding:0 14px;font-weight:650;display:inline-flex}.primary-button{color:#fff;background:var(--accent)}.primary-button:hover:not(:disabled){background:var(--accent-strong);transform:translateY(-1px)}.primary-button.compact{padding:0 16px}.alert{border-radius:8px;padding:10px 12px;font-size:13px}.alert-error{color:var(--danger);background:var(--danger-soft);border:1px solid #f4b7c2}.alert-success{color:var(--success);background:var(--success-soft);border:1px solid #b8e1c9}.toast-layer{z-index:60;pointer-events:none;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.toast-card{border:1px solid var(--border);width:min(420px,100vw - 32px);color:var(--ink);box-shadow:var(--floating-shadow);pointer-events:auto;background:#fffffff5;border-radius:8px;grid-template-columns:34px minmax(0,1fr) 28px;align-items:start;gap:12px;padding:16px;display:grid}.toast-icon{background:var(--panel-muted);border-radius:999px;place-items:center;width:34px;height:34px;display:inline-grid}.toast-success .toast-icon{color:var(--success);background:var(--success-soft)}.toast-error .toast-icon{color:var(--danger);background:var(--danger-soft)}.toast-info .toast-icon{color:var(--accent);background:var(--accent-soft)}.toast-card strong{color:var(--ink);font-size:15px;line-height:1.35;display:block}.toast-card p{color:var(--muted);margin:4px 0 0;font-size:13px;line-height:1.5}.toast-close{width:28px;min-height:28px;color:var(--muted);background:0 0;border:0;border-radius:999px;place-items:center;padding:0;display:inline-grid}.toast-close:hover{color:var(--ink);background:var(--panel-muted)}.app-shell{background:var(--panel-muted);grid-template-columns:244px minmax(0,1fr);min-height:100vh;display:grid}.sidebar{border-right:1px solid var(--border);background:#fff;flex-direction:column;gap:20px;min-height:100vh;padding:22px 14px;display:flex}.sidebar-header{grid-template-columns:34px minmax(0,1fr);align-items:center;gap:10px;padding:2px 6px 12px;display:grid}.sidebar-header strong,.sidebar-header span{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.sidebar-header strong{font-size:16px;font-weight:800}.sidebar-header span{color:var(--muted);margin-top:2px;font-size:12px}.product-nav{gap:18px;display:grid}.product-group{gap:7px;display:grid}.product-group h2{color:var(--muted);letter-spacing:.04em;margin:0 10px 3px;font-size:11px;font-weight:700}.nav-item{width:100%;min-height:38px;color:var(--ink);text-align:left;background:0 0;border:0;border-radius:999px;grid-template-columns:22px minmax(0,1fr) auto;align-items:center;gap:8px;padding:0 10px;display:grid}.nav-item:hover:not(:disabled),.nav-item.active{background:var(--accent-soft);color:var(--accent-strong)}.nav-item:disabled{color:#9aa39f}.module-badge{background:var(--panel-muted);color:var(--muted);border-radius:999px;padding:2px 6px;font-size:11px;font-weight:650}.module-badge.active{background:var(--success-soft);color:var(--success)}.nav-loading,.nav-error{color:var(--muted);align-items:center;gap:8px;padding:8px;font-size:13px;display:inline-flex}.nav-error{color:var(--danger)}.logout-button{width:100%;color:var(--muted);border-color:var(--border);background:#fff;margin-top:auto}.logout-button:hover{color:var(--ink);background:var(--panel-muted)}.workspace{min-width:0;padding:26px 28px}.workspace-header{justify-content:space-between;gap:16px;margin-bottom:20px;display:flex}.workspace-header h1,.detail-heading h2{color:var(--ink);letter-spacing:0;margin:0;font-size:30px;font-weight:820;line-height:1.05}.workspace-header p,.detail-heading p{color:var(--muted);margin:5px 0 0;font-size:13px}.region-stack{gap:14px;display:grid}.region-layout{grid-template-columns:minmax(0,1fr) minmax(280px,360px);align-items:start;gap:18px;display:grid}.region-tree-layout{grid-template-columns:minmax(320px,390px) minmax(0,1fr);align-items:start;gap:16px;display:grid}.region-main,.detail-panel,.table-panel,.tree-panel{border:1px solid var(--border);background:var(--panel);border-radius:8px;min-width:0}.region-main{background:0 0;border:0;gap:12px;display:grid}.toolbar{border:1px solid var(--border);background:#fff;border-radius:8px;grid-template-columns:minmax(260px,1fr) 136px 136px 100px 38px;gap:10px;padding:8px;display:grid}.roadbook-toolbar{grid-template-columns:minmax(260px,1fr) 136px 100px 38px}.tree-toolbar{grid-template-columns:minmax(260px,1fr) 136px 136px 122px 38px}.toolbar select{border-radius:999px;padding:0 10px}.search-form{border:1px solid var(--border);background:#fff;border-radius:999px;grid-template-columns:20px minmax(0,1fr) 66px;align-items:center;gap:8px;min-width:0;padding:0 8px;display:grid}.search-form:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #ede5fff2}.search-form input{min-height:36px;box-shadow:none;border:0;padding:0}.search-form button,.icon-button,.icon-text-button{color:var(--accent-strong);border-color:var(--border);background:#fff}.search-form button:hover,.icon-button:hover,.icon-text-button:hover:not(:disabled){background:var(--accent-soft);border-color:var(--accent-soft-strong)}.icon-button{width:38px;padding:0}.table-panel,.tree-panel{overflow:hidden}.tree-panel-header{border-bottom:1px solid var(--border);background:linear-gradient(135deg, var(--pastel-lilac), #fff 62%);grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;min-height:58px;padding:14px 14px 12px 16px;display:grid}.tree-panel-header strong,.tree-panel-header span{display:block}.tree-panel-header strong{color:var(--ink);font-size:14px}.tree-panel-header span{color:var(--muted);margin-top:3px;font-size:12px}.tree-actions{gap:8px;display:flex}.tree-actions button{border:1px solid var(--border);min-height:32px;color:var(--accent-strong);background:#fff;border-radius:999px;padding:0 9px;font-size:12px;font-weight:650}.tree-actions button:hover:not(:disabled){background:var(--accent-soft)}.region-tree-list{max-height:calc(100vh - 250px);padding:10px 8px;overflow:auto}.region-tree-row{border-radius:8px;grid-template-columns:26px minmax(0,1fr) auto 30px;align-items:center;gap:4px;padding-right:4px;display:grid}.tree-expander,.tree-row-edit{width:26px;min-height:32px;color:var(--muted);background:0 0;border:0;border-radius:999px;padding:0}.tree-expander:hover:not(:disabled),.tree-row-edit:hover:not(:disabled){color:var(--accent-strong);background:var(--accent-soft)}.tree-node-button{text-align:left;background:0 0;border:0;border-radius:8px;grid-template-columns:18px minmax(0,1fr);align-items:center;gap:8px;width:100%;min-height:44px;padding-top:7px;padding-bottom:7px;padding-right:10px;display:grid}.tree-node-button:hover,.tree-node-button.selected{background:var(--accent-soft)}.tree-node-button.selected{box-shadow:inset 0 0 0 1px var(--accent-soft-strong)}.tree-root-button{background:var(--panel-muted);grid-template-columns:minmax(0,1fr) auto;margin-bottom:6px;padding-left:12px}.tree-node-button strong,.tree-node-button small{text-overflow:ellipsis;white-space:nowrap;min-width:0;display:block;overflow:hidden}.tree-node-button strong{color:var(--ink);font-size:13px}.tree-node-button small{color:var(--muted);margin-top:3px;font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:11px}.tree-count{min-width:28px;color:var(--muted);text-align:right;font-size:11px}.connection-banner{border:1px solid var(--border);width:fit-content;max-width:100%;min-height:42px;color:var(--danger);background:#fff;border-radius:999px;grid-template-columns:22px auto minmax(0,1fr) 38px;align-items:center;gap:10px;padding:0 10px 0 12px;font-size:13px;display:grid}.connection-banner.connected{color:var(--success);background:#fff;border-color:#cfe9d9}.connection-banner strong{color:inherit;font-size:13px}.connection-banner span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.table-summary,.pagination{min-height:46px;color:var(--muted);justify-content:space-between;align-items:center;gap:12px;padding:0 14px;font-size:13px;display:flex}.table-summary strong{color:var(--ink)}.roadbook-list-header{border-bottom:1px solid var(--border);background:#fff;justify-content:space-between;align-items:center;gap:12px;min-height:64px;padding:14px 16px;display:flex}.roadbook-list-title{gap:4px;min-width:0;display:grid}.roadbook-list-title strong{color:var(--ink);text-overflow:ellipsis;white-space:nowrap;font-size:16px;font-weight:800;overflow:hidden}.roadbook-list-title span,.roadbook-region-meta span,.roadbook-region-text span,.roadbook-region-text small{color:var(--muted);font-size:12px}.roadbook-list-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.inline-link-button{min-height:28px;color:var(--accent-strong);border-color:var(--border);background:#fff;border-radius:999px;margin-left:8px;padding:0 8px;font-size:12px}.inline-link-button:hover{background:var(--accent-soft)}.pagination{border-top:1px solid var(--border);justify-content:flex-end}.region-table-wrap{border-top:1px solid var(--border);overflow:auto}.region-table{border-collapse:collapse;width:100%;min-width:980px;font-size:13px}.region-table th,.region-table td{vertical-align:middle;text-align:left;border-bottom:1px solid #eeeeea;padding:11px 12px}.region-table th{z-index:1;color:var(--muted);background:#fbfbf8;font-size:12px;font-weight:700;position:sticky;top:0}.region-table tbody tr{cursor:pointer}.region-table tbody tr:hover,.region-table tbody tr.selected{background:var(--accent-soft)}.roadbook-tree-region-table{min-width:920px}.roadbook-region-rows{min-height:220px}.roadbook-region-row{background:#fff;border-bottom:1px solid #eeeeea;grid-template-columns:minmax(280px,1.4fr) 128px minmax(160px,.8fr) 112px minmax(260px,auto);align-items:center;gap:14px;padding:14px 16px;display:grid}.roadbook-region-row:last-child{border-bottom:0}.roadbook-region-row:hover{background:#fbf9ff}.roadbook-region-main-cell{align-items:center;gap:12px;min-width:0;display:flex}.roadbook-region-cover{width:68px;height:68px;color:var(--muted);background:var(--pastel-mint);box-shadow:inset 0 0 0 1px var(--border);border-radius:8px;flex:0 0 68px;place-items:center;display:inline-grid;overflow:hidden}.roadbook-region-cover img{object-fit:cover;width:100%;height:100%;display:block}.roadbook-region-text{gap:4px;min-width:0;display:grid}.roadbook-region-text strong,.roadbook-region-text span,.roadbook-region-text small,.roadbook-region-meta strong,.roadbook-region-meta span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.roadbook-region-text strong,.roadbook-region-meta strong{color:var(--ink);font-size:14px}.roadbook-region-meta{min-width:0;color:var(--muted);gap:5px;font-size:12px;display:grid}.roadbook-row-actions{justify-content:flex-end}.region-table td strong,.region-table td span{text-overflow:ellipsis;white-space:nowrap;max-width:230px;display:block;overflow:hidden}.region-table td span{color:var(--muted);margin-top:3px;font-size:12px}.mono{font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:12px}.table-state{width:100%;min-height:70px;color:var(--muted);justify-content:center;align-items:center;gap:8px;display:inline-flex}.status-badge{border-radius:999px;align-items:center;min-height:24px;padding:0 8px;font-size:12px;font-weight:750;display:inline-flex}.status-active{color:var(--success);background:var(--success-soft)}.status-inactive{color:var(--warning);background:var(--warning-soft)}.status-deleted{color:var(--danger);background:var(--danger-soft)}.row-action{min-height:30px;color:var(--accent-strong);border-color:var(--border);background:#fff;border-radius:999px;padding:0 10px;font-size:12px}.row-actions{flex-wrap:wrap;gap:8px;display:flex}.row-action:hover:not(:disabled),.wide-action:hover:not(:disabled){background:var(--accent-soft)}.row-action.danger,.wide-action.danger{color:var(--danger)}.row-action.danger:hover:not(:disabled),.wide-action.danger:hover:not(:disabled){background:var(--danger-soft)}.detail-panel{background:linear-gradient(#ddf7ebb3,#0000 130px),#fff;gap:16px;padding:18px;display:grid;position:sticky;top:24px}.detail-heading{grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:10px;display:grid}.detail-heading h2{overflow-wrap:anywhere;font-size:18px}.wide-action{width:100%;color:var(--accent-strong);border-color:var(--border);background:#fff}.tree-edit-form{gap:10px;display:grid}.tree-edit-form label{color:var(--muted);gap:5px;font-size:12px;display:grid}.tree-edit-form input,.tree-edit-form select,.tree-edit-form textarea{border:1px solid var(--border);width:100%;min-width:0;min-height:40px;color:var(--ink);background:#fff;border-radius:8px;outline:none}.tree-edit-form input,.tree-edit-form select{padding:0 12px}.tree-edit-form textarea{resize:vertical;padding:10px 12px}.tree-edit-form input:focus,.tree-edit-form select:focus,.tree-edit-form textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #ede5fff2}.tree-checkbox{grid-template-columns:18px minmax(0,1fr);align-items:center}.tree-checkbox input{width:16px;min-height:16px}.detail-list{gap:0;margin:0;display:grid}.detail-list div{border-bottom:1px solid #eeeeea;grid-template-columns:84px minmax(0,1fr);gap:12px;padding:10px 0;display:grid}.detail-list dt{color:var(--muted);font-size:12px}.detail-list dd{overflow-wrap:anywhere;min-width:0;color:var(--ink);margin:0;font-size:13px}.tag-list{flex-wrap:wrap;gap:8px;display:flex}.tag-list span{min-height:24px;color:var(--accent-strong);background:var(--accent-soft);border-radius:999px;align-items:center;padding:0 8px;font-size:12px;font-weight:650;display:inline-flex}.empty-detail,.empty-module{min-height:160px;color:var(--muted);justify-content:center;align-items:center;gap:8px;display:inline-flex}.empty-module{border:1px solid var(--border);background:var(--panel);border-radius:8px;width:100%}.modal-backdrop{z-index:20;background:#10182847;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.modal-panel{border:1px solid var(--border);background:var(--panel);width:min(520px,100%);max-height:min(720px,100vh - 40px);box-shadow:var(--floating-shadow);border-radius:8px;gap:16px;padding:20px;display:grid;overflow:auto}.compact-detail-list div{grid-template-columns:76px minmax(0,1fr)}.modal-actions{justify-content:flex-end;gap:10px;display:flex}@media (width<=1180px){.app-shell{grid-template-columns:220px minmax(0,1fr)}.region-layout,.region-tree-layout{grid-template-columns:1fr}.detail-panel{position:static}.roadbook-region-row{grid-template-columns:minmax(260px,1fr) minmax(150px,.7fr)}.roadbook-row-actions{grid-column:1/-1;justify-content:flex-start}}@media (width<=860px){.app-shell{grid-template-columns:1fr}.sidebar{border-right:0;border-bottom:1px solid var(--border);min-height:auto}.workspace{padding:18px}.toolbar,.tree-toolbar{grid-template-columns:1fr 1fr}.search-form{grid-column:1/-1}.roadbook-list-header{flex-direction:column;align-items:stretch}.roadbook-list-actions{justify-content:flex-start}.roadbook-region-row{grid-template-columns:1fr}}@media (width<=560px){.workspace{padding:14px}.toolbar,.tree-toolbar{grid-template-columns:1fr}.icon-button{width:100%}.tree-panel-header{grid-template-columns:1fr}.tree-actions{grid-template-columns:1fr;display:grid}.table-summary,.pagination{flex-direction:column;justify-content:center;align-items:stretch;padding:12px}.icon-text-button{width:100%}}
