:root{--accent: #4f46e5;--accent-weak: #eef2ff;--accent-ring: #c7d2fe;--bg: #f6f7f9;--panel: #ffffff;--ink: #1f2430;--muted: #6b7280;--line: #e7e9ee;--line-soft: #eef0f4;--shadow: 0 1px 2px rgba(16, 24, 40, .06), 0 1px 3px rgba(16, 24, 40, .1);--shadow-lg: 0 10px 30px rgba(16, 24, 40, .12);--radius: 14px;--radius-sm: 10px;--green: #16a34a;--amber: #d97706;--red: #dc2626}*{box-sizing:border-box}html,body{margin:0;height:100%}body{font-family:Pretendard,Apple SD Gothic Neo,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Malgun Gothic,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}button{font:inherit;cursor:pointer}#root{min-height:100vh}.app{display:flex;height:100vh;height:100dvh;overflow:hidden}.side{width:248px;background:var(--panel);border-right:1px solid var(--line);padding:0 12px 16px;display:flex;flex-direction:column;gap:6px;min-height:100vh}.brand{display:flex;align-items:center;justify-content:center;gap:10px;min-height:60px;margin:0 -12px;padding:0 20px;border-bottom:1px solid var(--line);background:none;border-top:none;border-left:none;border-right:none;cursor:pointer;width:auto;text-align:left;font:inherit;color:inherit}.logo{width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,var(--accent),#8b5cf6);display:grid;place-items:center;color:#fff;font-weight:800}.brand b{font-size:15px}.side-action{display:flex;align-items:center;justify-content:flex-end;margin:0 -12px;padding:6px 12px;border-bottom:1px solid var(--line)}.side-action .side-add{width:auto}.side-add{display:inline-flex;align-items:center;justify-content:center;gap:5px;height:30px;padding:0 10px;border:1px solid var(--accent-ring);background:var(--accent-weak);color:var(--accent);font:inherit;font-size:12.5px;font-weight:700;border-radius:8px;cursor:pointer}.side-add:hover{background:#e7e9ff}.side-add-plus{font-size:16px;line-height:1}.ws{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:10px;color:var(--muted);font-weight:600;font-size:14px;border:0;background:transparent;width:100%;text-align:left}.ws:hover{background:var(--line-soft);color:var(--ink)}.ws.active{background:var(--accent-weak);color:var(--accent)}.ws .dot{width:9px;height:9px;border-radius:3px;background:var(--accent)}.ws-sub{display:flex;flex-direction:column;gap:1px;margin:-2px 0 2px 22px}.subnav{text-align:left;border:none;background:none;cursor:pointer;font:inherit;font-size:13px;color:var(--muted);padding:6px 10px;border-radius:8px}.subnav:hover{background:var(--line-soft);color:var(--ink)}.subnav.on{color:var(--accent);background:var(--accent-weak);font-weight:600}.navlabel{font-size:11px;letter-spacing:.06em;color:#9aa1ad;font-weight:700;padding:14px 10px 6px;text-transform:uppercase}.me{margin-top:auto;display:flex;align-items:center;gap:10px;padding:8px;border-top:1px solid var(--line)}.me .me-name{font-size:13px;font-weight:700}.me .me-sub{font-size:11px;color:var(--muted)}.logout-btn{margin-left:auto;border:1px solid var(--line);background:var(--panel);color:var(--muted);font:inherit;font-size:12px;font-weight:600;padding:6px 9px;border-radius:8px;cursor:pointer;white-space:nowrap}.logout-btn:hover{background:var(--line-soft);color:var(--ink)}.main{flex:1;min-width:0;min-height:0;display:flex;flex-direction:column}.top{flex:none;min-height:60px;display:flex;align-items:center;gap:14px;padding:0 22px;border-bottom:1px solid var(--line);background:var(--panel)}.main-body{flex:1;min-height:0;overflow:auto;display:flex;flex-direction:column}.top h1{font-size:16px;margin:0}.crumb,.top-sub{color:var(--muted);font-size:13px}.spacer{flex:1}.btn{border:1px solid var(--line);background:var(--panel);color:var(--ink);padding:8px 13px;border-radius:10px;font-weight:600;font-size:13px;white-space:nowrap}.btn:hover{background:var(--line-soft)}.btn.primary{background:var(--accent);border-color:transparent;color:#fff}.btn.primary:hover{filter:brightness(1.05)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn.block{width:100%;justify-content:center;padding:11px;display:flex}.av{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:11px;font-weight:700;border:2px solid #fff}.live{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--muted);font-weight:600}.pulse{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 #16a34a80;animation:p 2s infinite}@keyframes p{0%{box-shadow:0 0 #16a34a80}70%{box-shadow:0 0 0 7px #16a34a00}to{box-shadow:0 0 #16a34a00}}.board{display:flex;gap:16px;padding:20px 22px;overflow-x:auto;align-items:flex-start}.col{flex:0 0 290px;background:#f1f2f5;border:1px solid var(--line);border-radius:var(--radius);padding:10px;display:flex;flex-direction:column;gap:10px}.col-h{display:flex;align-items:center;gap:8px;padding:4px 6px 2px}.col-h .name{font-weight:700;font-size:13.5px;margin:0}.col-h .count{background:#e2e5ea;color:var(--muted);font-size:11px;font-weight:700;border-radius:999px;padding:2px 8px}.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-sm);padding:12px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:9px}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px);transition:.12s}.card .title{font-size:14px;font-weight:600;line-height:1.4;margin:0}.card .card-desc{font-size:12.5px;color:var(--muted);line-height:1.5;margin:0}.card .meta{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:12px}.due{display:inline-flex;align-items:center;gap:5px;font-weight:600;padding:2px 7px;border-radius:6px;background:#f3f4f6}.due.soon{background:#fef3c7;color:#b45309}.due.over{background:#fee2e2;color:#b91c1c}.addcard-btn{width:100%;border:1px dashed #cdd2db;background:transparent;color:var(--muted);border-radius:10px;padding:9px;font:inherit;font-weight:600;font-size:13px;cursor:pointer;text-align:center}.addcard-btn:hover{background:#fff;color:var(--ink)}.menu-wrap{position:relative}.kebab{border:0;background:transparent;cursor:pointer;color:var(--muted);font-size:16px;line-height:1;padding:2px 7px;border-radius:7px}.kebab:hover{background:#e2e5ea;color:var(--ink)}.menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40}.menu-pop{position:absolute;top:100%;right:0;z-index:41;min-width:150px;margin-top:4px;background:var(--panel);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow-lg);padding:5px;display:flex;flex-direction:column;gap:2px}.menu-pop button{text-align:left;border:0;background:none;cursor:pointer;font:inherit;font-size:13px;padding:8px 10px;border-radius:7px;color:var(--ink)}.menu-pop button:hover{background:var(--line-soft)}.menu-pop button.danger{color:var(--red)}.menu-pop button.danger:hover{background:#fef2f2}.menu-note{margin:4px 8px 6px;font-size:12px;color:var(--muted)}.col-rename{flex:1;min-width:0;padding:4px 7px;border:1px solid var(--accent);border-radius:7px;font-size:13.5px;font-weight:700;outline:none}.bcard-managed{flex-direction:column}.bcard-foot{display:flex;align-items:center;gap:14px;padding:0 16px 14px;font-size:12.5px;color:var(--muted)}.bcard-foot .link-muted,.bcard-foot .link-danger{border:0;background:none;cursor:pointer;font:inherit;font-size:12.5px;padding:0}.link-muted{color:var(--muted)}.link-muted:hover{color:var(--ink)}.link-danger{color:var(--red)}.link-danger:hover{text-decoration:underline}.confirm-row{display:flex;align-items:center;gap:10px}.board-rename{width:100%;padding:6px 9px;border:1px solid var(--accent);border-radius:8px;font-size:14px;outline:none}.addcol{flex:0 0 280px;border:1px dashed #cdd2db;border-radius:var(--radius);color:var(--muted);font-weight:700;display:flex;flex-direction:column;gap:8px;padding:14px}.addcol input{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:9px;font-size:13px;outline:none;background:#fff}.addcol input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.vh{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.wrap{padding:26px 28px}.wrap-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px}.home-add{margin-bottom:18px}.modal.modal-sm{width:460px}.h2{font-size:20px;font-weight:800;margin:0 0 4px}.sub{color:var(--muted);font-size:13.5px;margin:0 0 22px}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(252px,1fr));gap:16px;list-style:none;padding:0;margin:0}.bcard{display:flex;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:0;overflow:hidden;box-shadow:var(--shadow);cursor:pointer}.bcard:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px);transition:.14s}.bcard a{text-decoration:none;color:inherit;display:flex;flex-direction:column;flex:1;min-width:0}.bcard .strip{height:8px}.bcard .body{padding:16px}.bcard h3{margin:0;font-size:15.5px}.new{background:var(--accent-weak);border:1px dashed var(--accent-ring);color:var(--accent);border-radius:var(--radius);display:flex;flex-direction:column;gap:10px;padding:18px;justify-content:center;min-height:140px}.new label{font-weight:700;font-size:13px}.new input{width:100%;padding:10px 12px;border:1px solid var(--accent-ring);border-radius:9px;font-size:14px;outline:none;background:#fff;color:var(--ink)}.new input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.login{min-height:100vh;display:grid;place-items:center;background:radial-gradient(1200px 500px at 70% -10%,var(--accent-weak),transparent),var(--bg)}.card-auth{width:380px;max-width:calc(100vw - 32px);background:var(--panel);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-lg);padding:28px}.card-auth .logo{width:42px;height:42px;border-radius:12px;margin:0 auto 14px}.card-auth h1,.card-auth h2{text-align:center;margin:0 0 4px;font-size:19px}.card-auth p.sub{text-align:center;margin:0 0 22px}.field{margin-bottom:14px}.field label{display:block;font-size:12.5px;font-weight:700;color:var(--muted);margin-bottom:6px}.field input{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:10px;font-size:14px;background:#fff;outline:none}.field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.hint{text-align:center;color:#9aa1ad;font-size:12px;margin-top:16px}.error{color:var(--red);font-size:13px;margin:0 0 12px}.backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:radial-gradient(900px 380px at 60% -8%,var(--accent-weak),transparent),#1018284d;display:grid;place-items:center;padding:34px;overflow:auto}.modal{width:780px;max-width:calc(100vw - 40px);max-height:90vh;background:var(--panel);border-radius:16px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden}.modal-h{display:flex;align-items:center;gap:10px;padding:13px 16px;border-bottom:1px solid var(--line)}.modal-h .crumb{font-size:12.5px;font-weight:700;color:var(--muted)}.modal .x{margin-left:auto;width:30px;height:30px;border-radius:8px;border:1px solid var(--line);background:#fff;color:var(--muted);font-weight:700}.modal-b{display:flex;flex-direction:column;gap:18px;padding:18px 20px;overflow:auto}.modal-b .field{margin-bottom:0}.wsadd-form{display:flex;flex-direction:column;gap:16px}.row3{display:grid;grid-template-columns:1fr 1fr;gap:14px}.modal-b select,.modal-b input{width:100%;padding:9px 10px;border:1px solid var(--line);border-radius:9px;font-size:13.5px;background:#fff;outline:none}.modal-b select:focus,.modal-b input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.rte{border:1px solid var(--line);border-radius:10px;background:#fff;overflow:hidden}.rte:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.rte-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:4px;padding:6px 8px;border-bottom:1px solid var(--line-soft);background:#fbfbfc}.rte-sep{width:1px;align-self:stretch;margin:2px 4px;background:var(--line)}.rte-hl{background:#fde68a;border-radius:3px;padding:0 3px;color:#3a4150;font-weight:700}.rte-btn{min-width:30px;height:28px;padding:0 7px;border:1px solid var(--line);border-radius:7px;background:#fff;color:var(--muted);font-size:13px;font-weight:600}.rte-btn:hover{background:var(--line-soft)}.rte-btn.active{background:var(--accent-weak);border-color:var(--accent-ring);color:var(--accent)}.rte-content{padding:0 12px}.rte-content .ProseMirror{min-height:280px;outline:none;font-size:13.5px;line-height:1.6;color:#3a4150}.rte-content .ProseMirror mark{background:#fde68a;border-radius:3px;padding:0 2px}.rte-content .ProseMirror a{color:var(--accent);text-decoration:underline;cursor:pointer}.rte-content .ProseMirror blockquote{border-left:3px solid var(--line);margin:8px 0;padding:2px 0 2px 12px;color:var(--muted)}.rte-content .ProseMirror pre{background:#0f172a;color:#e2e8f0;border-radius:8px;padding:12px 14px;font-size:12.5px;overflow-x:auto}.rte-content .ProseMirror pre code{background:none;color:inherit;padding:0}.rte-content .ProseMirror :not(pre)>code{background:#f1f2f5;border-radius:4px;padding:1px 5px;font-size:12.5px}.rte-content .ProseMirror table{border-collapse:collapse;width:100%;margin:8px 0;table-layout:fixed}.rte-content .ProseMirror th,.rte-content .ProseMirror td{border:1px solid var(--line);padding:6px 9px;vertical-align:top;min-width:40px}.rte-content .ProseMirror th{background:var(--line-soft);font-weight:700;text-align:left}.rte-content .ProseMirror .selectedCell{background:var(--accent-weak)}.rte-content .ProseMirror .column-resize-handle{background:var(--accent);width:3px}textarea.desc{width:100%;box-sizing:border-box;height:80px;border:1px solid var(--line);border-radius:10px;padding:12px;font:inherit;font-size:13.5px;color:#3a4150;line-height:1.6;background:#fff;resize:none;outline:none}textarea.desc:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.modal-actions{display:flex;gap:8px}.btn.danger{color:var(--red);border-color:#f3c6c6;background:#fff}.btn.danger:hover{background:#fef2f2}.subtabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin:0 0 18px}.subtab{border:0;background:transparent;color:var(--muted);font-weight:700;font-size:13.5px;padding:10px 4px;margin-right:18px;border-bottom:2px solid transparent}.subtab.on{color:var(--accent);border-bottom-color:var(--accent)}.banner{display:flex;align-items:center;gap:9px;background:var(--accent-weak);border:1px solid var(--accent-ring);color:#3949ab;border-radius:10px;padding:10px 13px;font-size:13px;font-weight:600;margin-bottom:16px}.tbl{width:100%;border-collapse:collapse;background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden}.tbl th{text-align:left;font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:#9aa1ad;font-weight:700;padding:12px 16px;background:#fafbfc;border-bottom:1px solid var(--line)}.tbl td{padding:12px 16px;border-bottom:1px solid var(--line-soft);font-size:13.5px;vertical-align:middle}.tbl tr:last-child td{border-bottom:0}.tbl tr:hover td{background:#fafbfc}.row-actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:nowrap}.row-actions .btn{flex:none;white-space:nowrap}.u{display:flex;align-items:center;gap:11px}.u .nm{font-weight:700}.u .em{color:var(--muted);font-size:12px}.rolesel{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line);border-radius:8px;padding:6px 11px;font-size:12.5px;font-weight:700;background:#fff;color:var(--ink)}.rolesel.admin{color:var(--accent);background:var(--accent-weak);border-color:var(--accent-ring)}.rolesel.lock{color:#aab;background:#f6f7f9;cursor:not-allowed}.iconbtn{width:32px;height:32px;border-radius:8px;border:1px solid var(--line);background:#fff;color:var(--muted)}.iconbtn:hover{background:#fef2f2;color:var(--red);border-color:#f3c6c6}.iconbtn.lock,.iconbtn:disabled{color:#cdd2db;cursor:not-allowed}.iconbtn.lock:hover,.iconbtn:disabled:hover{background:#fff;color:#cdd2db;border-color:var(--line)}.you{font-size:11px;font-weight:700;color:var(--accent);background:var(--accent-weak);border-radius:6px;padding:2px 7px;margin-left:6px}.badge{font-size:11px;font-weight:700;border-radius:999px;padding:3px 9px;background:#f1f2f5;color:var(--muted)}.danger-zone{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:28px;padding:16px 18px;border:1px solid var(--red);border-radius:14px;background:#fef2f2}.dz-title{font-weight:800;font-size:14px;color:var(--red);margin-bottom:2px}.b-wait{background:#fef3c7;color:#b45309}.b-ok{background:#dcfce7;color:#15803d}.invite-form{display:flex;align-items:flex-end;gap:12px;margin-bottom:16px;flex-wrap:wrap}.invite-form .field{margin-bottom:0}.invite-form .btn{padding-top:11px;padding-bottom:11px}.invite-form select{padding:11px 12px;border:1px solid var(--line);border-radius:10px;font-size:14px;background:#fff;outline:none}.invite-link{display:flex;align-items:center;gap:10px;background:var(--accent-weak);border:1px solid var(--accent-ring);border-radius:10px;padding:10px 13px;margin-bottom:16px}.invite-link code{flex:1;font-size:12.5px;word-break:break-all;color:#3949ab}.invrow{display:flex;align-items:center;gap:12px;padding:9px 0;border-top:1px solid var(--line-soft);font-size:13px}.invrow span:first-child{flex:1}.cal-top{display:flex;align-items:center;gap:8px}.cal-menu{margin-right:8px}.cal-top b{min-width:130px;text-align:center}.cal-title-wrap{position:relative}.cal-title{min-width:130px;text-align:center;border:0;background:none;cursor:pointer;font:inherit;font-weight:700;font-size:15px;padding:7px 10px;border-radius:8px;color:var(--ink)}.cal-title:hover{background:var(--line-soft)}.cal-picker-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:49}.cal-picker{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:6px;z-index:50;width:248px;background:var(--panel);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-lg);padding:10px}.cal-picker-year{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;font-size:14px}.cal-picker-nav{border:1px solid var(--line);background:var(--panel);border-radius:7px;width:30px;height:30px;cursor:pointer;font-size:15px;color:var(--muted)}.cal-picker-nav:hover{background:var(--line-soft);color:var(--ink)}.cal-picker-months{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.cal-month{border:1px solid var(--line);background:var(--panel);border-radius:8px;padding:9px 0;font-size:13px;font-weight:600;cursor:pointer;color:var(--ink)}.cal-month:hover{background:var(--line-soft)}.cal-month.on{background:var(--accent);color:#fff;border-color:var(--accent)}.cal-top .btn{height:38px;display:inline-flex;align-items:center}.cal-top .cal-nav{width:38px;padding:0;justify-content:center;font-size:16px}.cal-layout{display:flex;flex:1;min-height:0;align-items:stretch}.cal-main{flex:2;min-width:0;display:flex;flex-direction:column;overflow-y:auto}.cal-detail{flex:1;min-width:320px;max-width:460px;border-left:1px solid var(--line);background:var(--panel)}.cal-detail-form{display:flex;flex-direction:column;height:100%}.cal-detail-h{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--line)}.cal-detail .x{margin-left:auto}.cal-detail-bar{display:flex;justify-content:flex-end;gap:8px;padding:10px 16px;border-bottom:1px solid var(--line)}.cal-detail-bar .btn{padding:7px 14px;font-size:13px}.cal-detail-b{flex:1;min-height:0;overflow-y:auto}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-template-rows:auto;grid-auto-rows:1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;margin:16px;flex:1;min-height:0}.cal-head{background:#eef0f4;padding:8px;text-align:center;font-size:12px;font-weight:700;color:var(--ink)}.cal-cell{background:var(--panel);border:none;min-height:96px;padding:6px;text-align:left;display:flex;flex-direction:column;gap:4px;align-items:stretch;cursor:pointer;font:inherit;overflow:hidden}.cal-cell:hover{background:var(--accent-weak)}.cal-cell.out{background:var(--bg)}.cal-date{font-size:12px;font-weight:600;color:var(--ink)}.cal-cell.out .cal-date{color:var(--muted)}.cal-cell.today .cal-date{background:var(--accent);color:#fff;border-radius:999px;padding:1px 6px;min-width:18px;text-align:center}.cal-cell-head{display:flex;align-items:center;justify-content:space-between;gap:6px}.cal-more{font-size:11px;font-weight:700;color:var(--muted);padding:1px 6px;border-radius:6px;cursor:pointer;flex:none}.cal-more:hover{background:var(--line-soft);color:var(--ink)}.daylist{display:flex;flex-direction:column;gap:2px;padding:12px 14px}.daylist-item{display:flex;align-items:center;gap:9px;border:none;background:none;cursor:pointer;font:inherit;text-align:left;padding:8px 10px;border-radius:8px}.daylist-item:hover{background:var(--line-soft)}.daylist-dot{width:8px;height:8px;border-radius:50%;flex:none}.daylist-time{font-size:12px;color:var(--muted);min-width:52px}.daylist-title{font-size:13.5px;color:var(--ink)}.cal-chip{display:flex;gap:4px;align-items:baseline;background:var(--accent-weak);color:var(--accent);border-radius:6px;padding:2px 6px;font-size:12px;cursor:pointer;overflow:hidden;white-space:nowrap;box-shadow:inset 0 0 0 0 transparent;transition:box-shadow .08s ease}.cal-chip:hover{box-shadow:inset 0 0 0 2px #1118288c}.cal-chip.allday{background:var(--accent);color:#fff}.cal-chip-time{font-weight:600;flex-shrink:0}.cal-chip-title{overflow:hidden;text-overflow:ellipsis}.check{display:flex;align-items:center;gap:6px;font-size:14px;color:var(--ink)}.check input[type=checkbox]{width:auto;margin:0;padding:0;flex:none}.swatches{display:flex;gap:8px}.swatch{width:26px;height:26px;border-radius:50%;border:2px solid transparent;padding:0;cursor:pointer;outline-offset:2px}.swatch.sel{border-color:var(--ink);box-shadow:0 0 0 2px var(--panel) inset}.modal-wide{width:1080px}.modal-cols{display:flex;flex:1;min-height:0}.modal-cols>.modal-b{flex:1;min-width:0;overflow-y:auto}.comments{width:360px;flex:none;border-left:1px solid var(--line);padding:16px 18px;display:flex;flex-direction:column;min-height:0;overflow-y:auto}.comments-h{margin:0 0 12px;font-size:14px}.comment-list{list-style:none;margin:0 0 14px;padding:0;display:flex;flex-direction:column;gap:12px}.comment{display:flex;flex-direction:column;gap:4px}.comment-meta{display:flex;align-items:center;flex-wrap:wrap;gap:4px 8px;font-size:12.5px}.comment-author{font-weight:700;color:var(--ink)}.comment-time{color:var(--muted);font-size:11.5px;margin-left:auto}.comment-edited{color:var(--muted);font-size:11.5px}.comment-body{margin:0;white-space:pre-wrap;word-break:break-word;font-size:14px}.comment-actions{display:flex;gap:6px}.comment-actions .btn{padding:3px 10px;font-size:12.5px}.comment-edit{display:flex;flex-direction:column;gap:6px}.comment-form{display:flex;gap:8px;align-items:stretch;position:sticky;bottom:0;margin-top:auto;background:var(--panel);padding-top:10px}.comment-form textarea{flex:1;min-width:0;height:60px;min-height:44px}.comment-form .btn{flex:none;align-self:stretch}.comment-form textarea,.comment-edit textarea{width:100%;border:1px solid var(--line);border-radius:9px;padding:9px 10px;font:inherit;resize:vertical;box-sizing:border-box}.comment-form textarea:focus,.comment-edit textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring);outline:none}.docs-list{flex:1;min-width:260px;max-width:340px;display:flex;flex-direction:column;gap:6px;padding:16px;border-right:1px solid var(--line);overflow-y:auto}.docs-item{display:flex;flex-direction:column;gap:4px;padding:10px 12px;text-align:left;border:1px solid var(--line);border-radius:10px;background:#fff;cursor:pointer}.docs-item:hover{border-color:var(--accent)}.docs-item.on{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.docs-item-title{font-weight:700;font-size:14px}.docs-item-meta{font-size:12px;color:var(--muted)}.docs-tree{display:flex;flex-direction:column;gap:1px}.docs-branch{display:flex;flex-direction:column}.docs-node{display:flex;align-items:center;gap:2px;border-radius:8px;padding-right:4px}.docs-node:hover{background:var(--line-soft)}.docs-node.on{background:var(--accent-weak)}.docs-toggle{flex:none;width:18px;height:26px;border:0;background:none;cursor:pointer;color:var(--muted);font-size:10px;display:flex;align-items:center;justify-content:center}.docs-toggle-empty{cursor:default}.docs-node-title{flex:1;min-width:0;text-align:left;border:0;background:none;cursor:pointer;font:inherit;font-size:13.5px;font-weight:600;color:var(--ink);padding:6px 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.docs-node.on .docs-node-title{color:var(--accent)}.docs-add-child{flex:none;width:22px;height:22px;border:0;background:none;cursor:pointer;color:var(--muted);font-size:14px;border-radius:6px;opacity:.5}.docs-node:hover .docs-add-child{opacity:1}.docs-add-child:hover{background:#e2e5ea;color:var(--ink)}.docs-empty{color:#9aa1ad;font-size:13px;padding:24px}.hamburger{display:none;border:1px solid var(--line);background:var(--panel);color:var(--ink);width:38px;height:38px;border-radius:10px;font-size:17px;align-items:center;justify-content:center}.docs-back{display:none;border:none;background:none;color:var(--muted);font:inherit;font-size:13px;font-weight:600;padding:4px 2px;cursor:pointer}.docs-back:hover{color:var(--ink)}.doc-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.docs-new{background:var(--accent-weak);color:var(--accent);border-color:var(--accent-ring)}.docs-new:hover{background:#e7e9ff}.doc-title-row{display:flex;align-items:center;gap:8px}.doc-title-row input{flex:1;min-width:0}.doc-title-row .btn{flex:none}.doc-head-actions{display:flex;gap:8px;margin-left:auto}.doc-title{font-size:20px;font-weight:800;margin:0}.doc-meta{font-size:12.5px;color:var(--muted)}.doc-read{flex:1;min-height:0}.doc-read .rte-readonly{flex:1;min-height:0;display:flex;flex-direction:column;border:none;background:transparent;border-radius:0}.doc-read .rte-readonly .rte-content{flex:1;min-height:0;padding:0;overflow-y:auto}.doc-empty-body{color:#9aa1ad;font-size:13.5px}.doc-edit{flex:1;min-height:0;overflow:hidden}.doc-edit .doc-body,.doc-edit .doc-body .rte{flex:1;min-height:0;display:flex;flex-direction:column}.doc-edit .doc-body .rte-content{flex:1;min-height:0;padding:0;overflow:hidden}.doc-edit .doc-body .rte-content .ProseMirror{height:100%;min-height:0;overflow-y:auto;padding:8px 12px 12px}.top-action{display:none}.top-right{margin-left:auto;display:flex;align-items:center;gap:12px}.usermenu{position:relative}.usermenu-trigger{display:flex;align-items:center;gap:8px;border:1px solid var(--line);background:var(--panel);border-radius:999px;padding:3px 10px 3px 3px;cursor:pointer;font:inherit}.usermenu-trigger:hover{background:var(--line-soft)}.usermenu-trigger .av{width:28px;height:28px;border:none}.usermenu-role{font-size:13px;font-weight:700;color:var(--ink)}.usermenu-chev{font-size:10px;color:var(--muted)}.usermenu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70}.usermenu-panel{position:absolute;top:calc(100% + 8px);right:0;z-index:71;min-width:220px;background:var(--panel);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-lg);padding:6px}.usermenu-head{padding:10px 12px;border-bottom:1px solid var(--line-soft);margin-bottom:4px}.usermenu-name{font-size:14px;font-weight:700}.usermenu-email{font-size:12px;color:var(--muted)}.usermenu-item{width:100%;text-align:left;border:none;background:none;cursor:pointer;font:inherit;font-size:13.5px;padding:9px 12px;border-radius:8px;color:var(--ink)}.usermenu-item:hover{background:var(--line-soft)}.usermenu-item.danger{color:var(--red)}.usermenu-item.danger:hover{background:#fef2f2}.top-add{width:38px;height:38px;border-radius:10px;border:none;background:var(--accent);color:#fff;font-size:20px;font-weight:700;display:flex;align-items:center;justify-content:center}.profile{max-width:520px;background:var(--panel);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:22px;display:flex;flex-direction:column;gap:16px}.profile-head{display:flex;align-items:center;gap:14px}.profile-av{width:48px;height:48px;font-size:18px}.profile-email{font-size:15px;font-weight:700}.profile-ok{color:var(--green);font-size:13px;margin:0}.profile .field input:disabled{background:var(--bg);color:var(--muted)}.profile-ws{max-width:520px;margin-top:26px}.profile-ws-list{list-style:none;padding:0;margin:12px 0 0;display:flex;flex-direction:column;gap:8px}.profile-ws-item{display:flex;align-items:center;gap:10px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:12px 14px}.profile-ws-name{font-weight:600;font-size:14px}.profile-ws-item .rolesel{margin-left:auto}@media (max-width: 768px){.side{position:fixed;top:0;left:0;z-index:60;width:min(86vw,320px);transform:translate(-100%);transition:transform .2s ease;box-shadow:var(--shadow-lg)}.side.open{transform:translate(0)}.nav-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:55;background:#10182880}.hamburger{display:inline-flex}.board{padding:14px 12px;gap:12px;scroll-snap-type:x mandatory}.col{flex:0 0 85vw;scroll-snap-align:start}.cal-detail{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;min-width:0;max-width:none;border-left:none;overflow-y:auto}.cal-grid{margin:8px}.cal-head{padding:5px;font-size:11px}.cal-cell{min-height:52px;padding:3px}.cal-date{font-size:11px}.cal-layout{flex-direction:column}.docs-list{max-width:none;min-width:0}.cal-layout.docs-editing .docs-list{display:none}.docs-layout:not(.docs-editing) .cal-main{display:none}.docs-back{display:inline-flex}.docs-list>.btn.block{display:none}.backdrop{padding:12px}.modal,.modal.modal-wide,.modal.modal-sm{width:calc(100vw - 24px);max-width:calc(100vw - 24px)}.modal-cols{flex-direction:column}.wrap{padding:16px}.grid{grid-template-columns:1fr}.tbl th,.tbl td{padding:9px 10px;font-size:12.5px}.top-action{display:flex}.top{padding:0 12px;gap:8px}.usermenu-role,.top-sub,.home-add{display:none}.docs-item,.bcard{border-radius:14px;box-shadow:var(--shadow)}.card{border-radius:12px;box-shadow:var(--shadow)}}
