:root{--bg: oklch(.968 .003 250);--surface: #ffffff;--surface-2: oklch(.985 .002 250);--surface-3: oklch(.955 .004 250);--border: oklch(.915 .004 255);--border-2: oklch(.86 .006 255);--text: oklch(.27 .012 260);--text-2: oklch(.5 .012 260);--text-3: oklch(.64 .01 260);--accent: #3f6fd1;--accent-weak: color-mix(in srgb, var(--accent) 10%, white);--accent-weak-2: color-mix(in srgb, var(--accent) 16%, white);--accent-ink: color-mix(in srgb, var(--accent) 78%, black);--danger: oklch(.56 .17 26);--danger-weak: color-mix(in srgb, var(--danger) 11%, white);--ava0: oklch(.58 .12 255);--ava1: oklch(.6 .13 25);--ava2: oklch(.58 .12 155);--ava3: oklch(.58 .11 300);--ava4: oklch(.62 .12 70);--r: 12px;--r-sm: 9px;--r-lg: 16px;--shadow-sm: 0 1px 2px rgba(20,28,45,.05), 0 1px 1px rgba(20,28,45,.03);--shadow: 0 4px 16px -6px rgba(20,28,45,.12), 0 2px 6px -3px rgba(20,28,45,.07);--shadow-lg: 0 24px 60px -18px rgba(20,28,45,.28), 0 8px 20px -10px rgba(20,28,45,.14);--font: "IBM Plex Sans Thai", system-ui, sans-serif;--mono: "IBM Plex Mono", ui-monospace, monospace;color-scheme:light}*{box-sizing:border-box}html,body{margin:0;height:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-size:15px;line-height:1.5}#root{height:100%}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit;color:var(--text);caret-color:var(--accent)}input,textarea{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='24' viewBox='0 0 12 24'%3E%3Cpath d='M3 3h6M6 3v18M3 21h6' fill='none' stroke='%23ffffff' stroke-width='3.4' stroke-linecap='round'/%3E%3Cpath d='M3 3h6M6 3v18M3 21h6' fill='none' stroke='%23222b3d' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E") 6 12,text}.detail-text{cursor:default}::selection{background:var(--accent-weak-2)}.app{height:100%;display:flex;flex-direction:column;min-height:0}.topbar{height:60px;flex:0 0 60px;display:flex;align-items:center;gap:16px;padding:0 20px;background:var(--surface);border-bottom:1px solid var(--border);position:relative;z-index:30}.brand{display:flex;align-items:center;gap:11px;cursor:pointer;-webkit-user-select:none;user-select:none}.brand-mark{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;background:var(--text);color:#fff;font-weight:700;font-size:18px;letter-spacing:.02em}.brand-txt{display:flex;flex-direction:column;line-height:1.15}.brand-txt b{font-size:16px;font-weight:700;letter-spacing:.06em}.brand-txt span{font-size:11.5px;color:var(--text-3)}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:10px}.hamburger{display:none;align-items:center;justify-content:center;width:40px;height:40px;margin-left:-6px;border:0;border-radius:9px;background:transparent;color:var(--text-2);cursor:pointer;transition:.12s;flex:0 0 auto}.hamburger:hover{background:var(--surface-3);color:var(--text)}.sidebar-head{display:flex;align-items:center;justify-content:space-between}.icon-btn.sidebar-close,.sidebar-scrim{display:none}.nav-pill{display:flex;align-items:center;gap:7px;height:38px;padding:0 14px;border-radius:10px;border:1px solid var(--border-2);background:var(--surface);color:var(--text-2);font-size:14px;font-weight:500;transition:.13s}.nav-pill:hover{background:var(--surface-3);color:var(--text)}.nav-pill.on{background:var(--text);color:#fff;border-color:var(--text)}.userbox{position:relative}.user-btn{display:flex;align-items:center;gap:9px;height:42px;padding:0 8px 0 7px;border-radius:11px;border:1px solid transparent;background:transparent;color:var(--text);transition:.13s}.user-btn:hover{background:var(--surface-3)}.user-txt{display:flex;flex-direction:column;align-items:flex-start;line-height:1.2;gap:1px}.user-txt b{font-size:13.5px;font-weight:600}.user-btn svg{color:var(--text-3)}.menu-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40}.user-menu{position:absolute;right:0;top:calc(100% + 8px);width:296px;z-index:41;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-lg);padding:6px}.user-menu-h{font-size:11px;font-weight:600;letter-spacing:.04em;color:var(--text-3);text-transform:uppercase;padding:8px 10px 6px}.theme-box{position:relative}.nav-pill-icon{padding:0;width:40px;justify-content:center}.theme-menu{width:auto;min-width:228px}.theme-swatches{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:4px 6px 6px}.theme-sw{aspect-ratio:1;border-radius:10px;border:2px solid var(--border-2);cursor:pointer;display:grid;place-items:center;color:var(--text-2);transition:.12s;position:relative}.theme-sw:hover{transform:scale(1.05)}.theme-sw.on{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-weak)}.theme-sw svg{filter:drop-shadow(0 1px 1px rgba(0,0,0,.18))}.theme-sw-custom{background:linear-gradient(135deg,#faf5ec,#eaf2fb,#f2edfb,#fbedf1);overflow:hidden}.theme-sw-custom input,.swatch-custom input{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;border:0;padding:0}.color-picker{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.swatch{width:32px;height:32px;border-radius:9px;border:2px solid transparent;cursor:pointer;display:grid;place-items:center;color:#fff;transition:.12s;box-shadow:0 0 0 1px var(--border) inset;position:relative}.swatch:hover{transform:scale(1.06)}.swatch.on{border-color:var(--text);box-shadow:none}.swatch svg{filter:drop-shadow(0 1px 1px rgba(0,0,0,.35))}.swatch-none{background:var(--surface);color:var(--text-3);box-shadow:0 0 0 1px var(--border-2) inset}.swatch-none.on{border-color:var(--text)}.swatch-custom{background:linear-gradient(135deg,#f9637c,#f4cf3a,#5fc36a,#5b8def,#9b7ef0);overflow:hidden;color:#fff}.user-menu-i{width:100%;display:flex;align-items:center;gap:11px;padding:9px 10px;border-radius:9px;border:0;background:transparent;text-align:left;color:var(--text);transition:.1s}.user-menu-i:hover{background:var(--surface-3)}.user-menu-i.on{background:var(--accent-weak)}.user-menu-i div{flex:1;min-width:0;display:flex;flex-direction:column;line-height:1.25}.user-menu-i b{font-size:14px;font-weight:600}.user-menu-i span{font-size:11.5px;color:var(--text-3)}.user-menu-i>svg{color:var(--accent)}.shell{flex:1;display:flex;min-height:0}.sidebar{width:236px;flex:0 0 236px;border-right:1px solid var(--border);background:var(--surface);padding:16px 12px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.side-sec{font-size:11px;font-weight:600;letter-spacing:.05em;color:var(--text-3);text-transform:uppercase;padding:4px 10px 8px}.side-item{display:flex;align-items:center;gap:11px;width:100%;padding:9px 11px;border-radius:9px;border:0;background:transparent;color:var(--text-2);font-size:14.5px;font-weight:500;text-align:left;transition:.12s}.side-item svg{color:var(--text-3);flex:0 0 auto}.side-item span{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.side-count{font-size:12px;font-weight:600;color:var(--text-3);background:var(--surface-3);padding:1px 8px;border-radius:20px;min-width:24px;text-align:center}.side-item:hover{background:var(--surface-3);color:var(--text)}.side-item:hover svg{color:var(--text-2)}.side-item.on{background:var(--accent-weak);color:var(--accent-ink)}.side-item.on svg{color:var(--accent)}.side-item.on .side-count{background:color-mix(in srgb,var(--accent) 18%,white);color:var(--accent-ink)}.side-note{margin-top:auto;display:flex;align-items:center;gap:8px;padding:11px;font-size:12.5px;color:var(--text-3);background:var(--surface-2);border:1px solid var(--border);border-radius:9px}.main{flex:1;min-width:0;overflow-y:auto}.browse{max-width:1180px;margin:0 auto;padding:26px 28px 80px}.browse-head{display:flex;gap:12px;align-items:stretch;margin-bottom:18px}.search-wrap{flex:1;position:relative;display:flex;align-items:center}.search-ic{position:absolute;left:16px;color:var(--text-3);pointer-events:none}.search-input{width:100%;height:52px;padding:0 44px 0 48px;border-radius:13px;border:1px solid var(--border-2);background:var(--surface);color:var(--text);font-size:16px;outline:none;transition:.15s;box-shadow:var(--shadow-sm)}.search-input::placeholder{color:var(--text-3)}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-weak)}.search-clear{position:absolute;right:12px;width:28px;height:28px;display:grid;place-items:center;border:0;background:var(--surface-3);border-radius:7px;color:var(--text-2)}.search-clear:hover{background:var(--border)}.add-btn{flex:0 0 auto;height:52px;padding:0 20px;font-size:15px}.topcats{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.topcats-mobile{display:none}.topcat{display:flex;align-items:center;gap:7px;height:38px;padding:0 14px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text-2);font-size:14px;font-weight:500;transition:.12s}.topcat svg{color:var(--text-3)}.topcat:hover{background:var(--surface-3);color:var(--text)}.topcat.on{background:var(--text);color:#fff;border-color:var(--text)}.topcat.on svg{color:#fff}.subtabs{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid var(--border)}.subtab{display:flex;align-items:center;gap:7px;height:34px;padding:0 13px;border-radius:9px;border:1px solid var(--border);background:var(--surface);color:var(--text-2);font-size:13.5px;font-weight:600;transition:.12s}.subtab:hover{background:var(--surface-3);color:var(--text)}.subtab.on{background:var(--accent);border-color:var(--accent);color:#fff}.subtab-count{font-size:11.5px;font-weight:700;font-family:var(--mono);opacity:.65}.subtab.on .subtab-count{opacity:.85}.tagbar{display:flex;align-items:center;gap:7px;flex-wrap:wrap;margin-bottom:14px}.tagbar-ic{color:var(--text-3);margin-right:2px}.chip{height:30px;padding:0 12px;border-radius:20px;border:1px solid var(--border);background:var(--surface);color:var(--text-2);font-size:13px;font-weight:500;transition:.12s}.chip:hover{border-color:var(--border-2);color:var(--text)}.chip.on{background:var(--accent);border-color:var(--accent);color:#fff}.chip.clear{background:transparent;border-style:dashed;color:var(--text-3)}.result-bar{font-size:13px;color:var(--text-3);margin-bottom:14px;font-weight:500}.grid{column-gap:14px}.grid-comfortable{column-width:320px}.grid-compact{column-width:258px;column-gap:12px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:13px;display:flex;flex-direction:column;gap:9px;cursor:pointer;transition:.15s;box-shadow:var(--shadow-sm);position:relative;break-inside:avoid;-webkit-column-break-inside:avoid;margin-bottom:14px}.grid-compact .card{margin-bottom:12px}.card:hover{border-color:var(--border-2);box-shadow:var(--shadow);transform:translateY(-1px)}.card{cursor:grab}.card:active{cursor:grabbing}.card.card-dragging{opacity:.3;border-style:dashed;transform:scale(.97);box-shadow:none}.card.card-drop-before,.card.card-drop-after{border-color:var(--accent)}.card.card-drop-before:before,.card.card-drop-after:before{content:"";position:absolute;left:6px;right:6px;height:4px;border-radius:3px;background:var(--accent);box-shadow:0 0 0 3px var(--accent-weak)}.card.card-drop-before:before{top:-9px}.card.card-drop-after:before{bottom:-9px}.card.card-tinted{background:color-mix(in srgb,var(--card-color) 17%,var(--surface));border-color:color-mix(in srgb,var(--card-color) 42%,var(--border))}.card.card-tinted .card-answer{background:color-mix(in srgb,var(--card-color) 8%,#fff);border-color:color-mix(in srgb,var(--card-color) 26%,var(--border))}.card.card-tinted .card-cat{background:color-mix(in srgb,var(--card-color) 20%,#fff)}.grid-dragging .card:not(.card-dragging){transition:transform .15s,box-shadow .15s,border-color .15s}.grid-dragging{-webkit-user-select:none;user-select:none}.drag-handle{display:flex;align-items:center;color:var(--text-3);opacity:0;transition:opacity .12s;flex-shrink:0;cursor:grab}.card:hover .drag-handle{opacity:.7}.card.card-drag-over .drag-handle{opacity:0}.card-compact{padding:13px;gap:9px}.card-top{display:flex;align-items:center;gap:8px}.card-cat{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--accent-ink);background:var(--accent-weak);padding:4px 9px;border-radius:7px}.card-cat svg{color:var(--accent)}.card-actions{margin-left:auto;display:flex;align-items:center;gap:3px}.card-uses{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:var(--text-3)}.card-uses svg{color:var(--ava4)}.card-title{margin:0;font-size:15px;font-weight:700;line-height:1.3;letter-spacing:-.005em}.card-compact .card-title{font-size:15px}.card-answer{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);padding:10px;display:flex;flex-direction:column;gap:8px;align-items:flex-start}.card-text{margin:0;font-size:13.5px;line-height:1.55;color:var(--text-2);white-space:pre-wrap;word-break:break-word}.card-compact .card-text{font-size:13.5px}.copy-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;height:34px;padding:0 14px;border-radius:8px;border:1px solid var(--accent);background:var(--accent);color:#fff;font-size:13.5px;font-weight:600;transition:.13s;white-space:nowrap}.copy-btn:hover{background:var(--accent-ink);border-color:var(--accent-ink)}.copy-btn.is-copied{background:#1a8a51;border-color:#1a8a51}.card-text{width:100%}.copy-block{align-self:flex-end;box-shadow:var(--shadow-sm)}.card-answer-copy{cursor:pointer;transition:border-color .12s}.card-answer-copy:hover{border-color:var(--accent)}.card-answer-copy.is-copied{border-color:#1a8a51}.copy-hint{align-self:flex-end;display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;color:var(--text-3);background:var(--surface-3);padding:3px 8px;border-radius:6px;transition:.12s;-webkit-user-select:none;user-select:none}.card-answer-copy:hover .copy-hint{color:var(--accent);background:var(--accent-weak)}.card-answer-copy.is-copied .copy-hint{color:#fff;background:#1a8a51}.card-imgs{display:flex;gap:8px;flex-wrap:wrap}.card-foot{display:flex;align-items:flex-end;justify-content:space-between;gap:10px;margin-top:auto}.card-tags{display:flex;gap:5px;flex-wrap:wrap}.tag{font-size:11.5px;font-weight:500;color:var(--text-3);background:var(--surface-3);padding:2px 8px;border-radius:6px;font-family:var(--mono)}.card-meta{font-size:11.5px;color:var(--text-3);white-space:nowrap}.imgtile{position:relative;margin:0;border-radius:var(--r-sm);overflow:hidden;border:1px solid var(--border-2);background:var(--surface-3);cursor:pointer}.imgtile:hover{border-color:var(--accent)}.imgtile-sm{width:108px;height:84px}.imgtile-md{width:140px;height:104px}.imgtile-lg{width:170px;height:128px}.imgtile-stripes{position:absolute;top:0;right:0;bottom:0;left:0;background-image:repeating-linear-gradient(135deg,transparent 0 9px,rgba(0,0,0,.045) 9px 18px);background-color:var(--tile)}.imgtile-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.tone-a{--tile:oklch(.93 .03 255)}.tone-b{--tile:oklch(.93 .03 150)}.tone-c{--tile:oklch(.94 .035 70)}.tone-d{--tile:oklch(.93 .03 300)}.imgtile-cap{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;gap:5px;padding:7px 8px;font-size:11px;font-weight:500;color:var(--text-2);font-family:var(--mono)}.imgtile-cap svg{flex:0 0 auto;color:var(--text-3)}.imgtile-cap span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.imgtile-copy{position:absolute;left:6px;right:6px;bottom:6px;display:flex;align-items:center;justify-content:center;gap:5px;height:28px;border-radius:7px;border:0;background:#fffffff0;color:var(--text);font-size:11.5px;font-weight:600;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:var(--shadow-sm);opacity:0;transform:translateY(4px);transition:.14s}.imgtile:hover .imgtile-copy{opacity:1;transform:none}.imgtile.is-copied .imgtile-copy{opacity:1;transform:none;background:#1a8a51;color:#fff}@media(hover:none){.imgtile-copy{opacity:.92;transform:none}}.imgtile-lg .imgtile-copy{height:32px;font-size:12.5px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;height:42px;padding:0 18px;border-radius:10px;border:1px solid transparent;font-size:14.5px;font-weight:600;transition:.13s;white-space:nowrap}.btn.sm{height:34px;padding:0 13px;font-size:13.5px;border-radius:8px}.btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn.primary:hover{background:var(--accent-ink);border-color:var(--accent-ink)}.btn.ghost{background:var(--surface);color:var(--text-2);border-color:var(--border-2)}.btn.ghost:hover{background:var(--surface-3);color:var(--text)}.btn.danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn.danger:hover{filter:brightness(.95)}.btn.disabled{opacity:.4;pointer-events:none}.icon-btn{width:34px;height:34px;display:grid;place-items:center;border-radius:8px;border:0;background:transparent;color:var(--text-3);transition:.12s}.icon-btn:hover{background:var(--surface-3);color:var(--text)}.icon-btn.sm{width:30px;height:30px}.icon-btn.danger:hover{background:var(--danger-weak);color:var(--danger)}.icon-btn:disabled{opacity:.3;pointer-events:none}.avatar{display:grid;place-items:center;border-radius:50%;color:#fff;font-weight:600;flex:0 0 auto}.role-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:6px;white-space:nowrap}.role-admin{background:color-mix(in srgb,var(--ava0) 15%,white);color:color-mix(in srgb,var(--ava0) 70%,black)}.role-manager{background:color-mix(in srgb,var(--ava4) 18%,white);color:color-mix(in srgb,var(--ava4) 60%,black)}.role-staff{background:var(--surface-3);color:var(--text-2)}.empty{text-align:center;padding:64px 20px;color:var(--text-3)}.empty-ic{width:60px;height:60px;border-radius:16px;display:grid;place-items:center;background:var(--surface-3);color:var(--text-3);margin:0 auto 16px}.empty-t{font-size:16px;font-weight:600;color:var(--text-2);margin:0 0 4px}.empty-s{font-size:13.5px;margin:0}.modal-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;background:#141a2866;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:flex-start;justify-content:center;padding:40px 20px;overflow-y:auto;animation:fade .15s}@keyframes fade{0%{opacity:0}}.modal{width:560px;max-width:100%;background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);animation:pop .18s cubic-bezier(.3,.8,.4,1);margin:auto}.modal-wide{width:680px}@keyframes pop{0%{opacity:0;transform:translateY(12px) scale(.98)}}.modal-head{display:flex;align-items:center;gap:12px;padding:18px 20px;border-bottom:1px solid var(--border)}.modal-head h2{margin:0;font-size:18px;font-weight:700;flex:1}.modal-body{padding:20px;max-height:62vh;overflow-y:auto}.modal-foot{display:flex;align-items:center;gap:10px;justify-content:flex-end;padding:14px 20px;border-top:1px solid var(--border);background:var(--surface-2);border-radius:0 0 var(--r-lg) var(--r-lg)}.detail-answer{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r);padding:16px}.detail-text{margin:0;font-size:15px;line-height:1.7;color:var(--text);white-space:pre-wrap;word-break:break-word}.detail-label{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--text-2);margin:18px 0 10px}.detail-label svg{color:var(--text-3)}.detail-imgs{display:flex;gap:10px;flex-wrap:wrap}.detail-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:18px;padding-top:14px;border-top:1px dashed var(--border-2);flex-wrap:wrap}.detail-foot{display:flex;align-items:center;gap:10px;width:100%}.detail-foot .spacer{flex:1}.form{display:flex;flex-direction:column;gap:16px}.form-grid2{display:grid;grid-template-columns:1fr 200px;gap:14px}.field{display:flex;flex-direction:column;gap:7px}.field-label{font-size:13px;font-weight:600;color:var(--text-2)}.field-label em{font-style:normal;font-weight:400;color:var(--text-3);font-size:12px}.input{width:100%;height:42px;padding:0 13px;border-radius:9px;border:1px solid var(--border-2);background:var(--surface);color:var(--text);font-size:14.5px;outline:none;transition:.13s}.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-weak)}.textarea{height:auto;padding:11px 13px;line-height:1.6;resize:vertical;min-height:120px}.select-wrap{position:relative}.select-wrap select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.select-ic{position:absolute;right:11px;top:50%;transform:translateY(-50%);color:var(--text-3);pointer-events:none}.img-editor{display:flex;flex-direction:column;gap:8px}.img-edit-row{display:flex;align-items:center;gap:10px;padding:8px;border:1px solid var(--border);border-radius:9px;background:var(--surface-2)}.img-edit-thumb{position:relative;width:48px;height:38px;flex:0 0 auto;border-radius:7px;overflow:hidden;border:1px solid var(--border-2);display:grid;place-items:center;color:var(--text-3)}.img-edit-thumb svg{position:relative;z-index:1}.img-edit-thumb img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;z-index:2}.img-edit-label{flex:1;height:38px}.add-img-btn{display:flex;align-items:center;justify-content:center;gap:7px;height:42px;border-radius:9px;border:1.5px dashed var(--border-2);background:transparent;color:var(--text-2);font-size:14px;font-weight:500;transition:.13s}.add-img-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-weak)}.tag-editor{display:flex;align-items:center;gap:7px;flex-wrap:wrap;padding:8px;border:1px solid var(--border-2);border-radius:9px;min-height:42px}.tag-edit{display:inline-flex;align-items:center;gap:5px;font-size:12.5px;padding:3px 4px 3px 9px}.tag-edit button{width:18px;height:18px;display:grid;place-items:center;border:0;background:var(--border);border-radius:5px;color:var(--text-2)}.tag-edit button:hover{background:var(--border-2)}.tag-input{flex:1;min-width:120px;border:0;outline:none;background:transparent;font-size:14px;height:28px;color:var(--text)}.role-pick{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.role-opt{display:flex;flex-direction:column;align-items:flex-start;gap:3px;padding:11px;border-radius:10px;border:1px solid var(--border-2);background:var(--surface);text-align:left;transition:.12s}.role-opt svg{color:var(--text-3);margin-bottom:3px}.role-opt b{font-size:14px;font-weight:600}.role-opt span{font-size:11.5px;color:var(--text-3);line-height:1.3}.role-opt:hover{border-color:var(--border-2);background:var(--surface-3)}.role-opt.on{border-color:var(--accent);background:var(--accent-weak)}.role-opt.on svg{color:var(--accent)}.check-row{display:flex;align-items:center;gap:9px;font-size:14px;color:var(--text-2);padding:7px 2px;cursor:pointer}.check-row svg{color:var(--text-3)}.check-row.master{font-weight:600;color:var(--text);border-bottom:1px solid var(--border);padding-bottom:11px;margin-bottom:4px}.check-row input{width:17px;height:17px;accent-color:var(--accent);cursor:pointer}.check-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px 16px}.hint{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-2);background:var(--accent-weak);padding:11px 13px;border-radius:9px;margin:0}.hint svg{color:var(--accent);flex:0 0 auto}.settings{max-width:1080px;margin:0 auto;padding:26px 28px 80px}.settings-top{margin-bottom:22px}.settings-top h2{display:flex;align-items:center;gap:9px;margin:0 0 16px;font-size:21px;font-weight:700}.settings-top h2 svg{color:var(--text-2)}.set-tabs{display:flex;gap:4px;background:var(--surface-3);padding:4px;border-radius:11px;width:fit-content}.set-tab{display:flex;align-items:center;gap:7px;height:36px;padding:0 15px;border-radius:8px;border:0;background:transparent;color:var(--text-2);font-size:14px;font-weight:500;transition:.12s}.set-tab svg{color:var(--text-3)}.set-tab:hover{color:var(--text)}.set-tab.on{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.set-tab.on svg{color:var(--accent)}.set-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:22px}.set-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.set-head h3{margin:0 0 3px;font-size:17px;font-weight:700}.set-head p{margin:0;font-size:13px;color:var(--text-3)}.emp-table{display:flex;flex-direction:column}.emp-row{display:grid;grid-template-columns:1.8fr .9fr .9fr .7fr auto;align-items:center;gap:12px;padding:12px 6px;border-top:1px solid var(--border)}.emp-head{border-top:0;font-size:11.5px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:var(--text-3);padding-bottom:6px}.emp-row.off{opacity:.55}.emp-id{display:flex;align-items:center;gap:11px}.emp-id div{display:flex;flex-direction:column;line-height:1.3;min-width:0}.emp-id b{font-size:14.5px;font-weight:600}.emp-id span{font-size:12px;color:var(--text-3);font-family:var(--mono)}.emp-access{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-2)}.emp-access svg{color:var(--text-3)}.emp-actions{display:flex;gap:2px;justify-content:flex-end}.switch{width:42px;height:24px;border-radius:20px;border:0;background:var(--border-2);position:relative;transition:.15s;padding:0}.switch i{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 2px #00000040;transition:.15s}.switch.on{background:#349d62}.switch.on i{transform:translate(18px)}.cat-add{display:flex;align-items:center;gap:9px;padding:12px;background:var(--accent-weak);border-radius:10px;margin-bottom:14px}.cat-add>svg{color:var(--accent)}.cat-add .input{flex:1;background:var(--surface)}.cat-list{display:flex;flex-direction:column}.cat-block{border-top:1px solid var(--border);padding:6px 0 12px}.cat-block:first-child{border-top:0}.cat-item{display:flex;align-items:center;gap:12px;padding:8px 6px}.cat-ic{width:36px;height:36px;flex:0 0 auto;display:grid;place-items:center;border-radius:9px;background:var(--accent-weak);color:var(--accent)}.cat-name{flex:1;font-size:15px;font-weight:600}.cat-edit{flex:1;max-width:300px;height:36px}.cat-count{font-size:12.5px;color:var(--text-3);font-family:var(--mono)}.cat-subs{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:2px 6px 0 54px}.cat-subs-label{display:flex;align-items:center;gap:5px;font-size:12.5px;font-weight:600;color:var(--text-3)}.subchip{display:inline-flex;align-items:center;gap:2px;height:28px;padding:0 4px 0 10px;border-radius:8px;border:1px solid var(--border-2);background:var(--surface-2)}.subchip-name{font-size:13px;font-weight:500;color:var(--text);background:transparent;border:0;cursor:pointer;padding:0}.subchip-x{width:20px;height:20px;display:grid;place-items:center;border:0;border-radius:6px;background:transparent;color:var(--text-3);cursor:pointer}.subchip-x:hover{background:var(--danger-weak);color:var(--danger)}.subchip-add{display:inline-flex;align-items:center;gap:5px;height:28px;padding:0 11px;border-radius:8px;border:1.5px dashed var(--border-2);background:transparent;color:var(--text-2);font-size:12.5px;font-weight:600;cursor:pointer;transition:.12s}.subchip-add:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-weak)}.sub-edit-input{height:28px;padding:0 9px;border-radius:8px;border:1px solid var(--accent);background:var(--surface);color:var(--text);font-size:13px;outline:none;min-width:120px;box-shadow:0 0 0 3px var(--accent-weak)}.perm-scroll{overflow-x:auto}.perm-matrix{display:grid;gap:1px;min-width:520px}.perm-corner{font-size:11px;font-weight:600;color:var(--text-3);padding:10px;position:sticky;left:0;background:var(--surface)}.perm-emp{display:flex;flex-direction:column;align-items:center;gap:5px;padding:10px 6px}.perm-emp span{font-size:11.5px;color:var(--text-2);font-weight:500}.perm-cat{display:flex;align-items:center;gap:8px;font-size:13.5px;font-weight:500;padding:0 10px;position:sticky;left:0;background:var(--surface)}.perm-cat svg{color:var(--text-3)}.perm-cell{height:46px;border:0;border-radius:8px;background:var(--surface-3);display:grid;place-items:center;color:transparent;transition:.1s;margin:1px}.perm-cell:hover{background:var(--border)}.perm-cell.on{background:var(--accent-weak);color:var(--accent)}.perm-cell.on:hover{background:var(--accent-weak-2)}.confirm{width:380px;max-width:100%;background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:22px;animation:pop .18s cubic-bezier(.3,.8,.4,1);margin:auto}.confirm h3{margin:0 0 6px;font-size:17px;font-weight:700}.confirm p{margin:0 0 18px;font-size:14px;color:var(--text-2)}.confirm-foot{display:flex;gap:10px;justify-content:flex-end}.auth-wrap{min-height:100%;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg)}.auth-card{width:380px;max-width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:28px;display:flex;flex-direction:column;gap:14px}.auth-brand{display:flex;align-items:center;gap:11px;margin-bottom:2px}.auth-title{margin:6px 0 0;font-size:21px;font-weight:700}.auth-sub{margin:0 0 6px;font-size:13.5px;color:var(--text-3);line-height:1.5}.auth-msg{margin:0;font-size:13px;padding:10px 12px;border-radius:9px}.auth-err{color:var(--danger);background:var(--danger-weak)}.auth-ok{color:color-mix(in srgb,oklch(.56 .13 155) 80%,black);background:color-mix(in srgb,oklch(.62 .13 155) 14%,white)}.auth-switch{font-size:13.5px;color:var(--text-3);text-align:center;margin-top:2px}.auth-switch button{border:0;background:transparent;color:var(--accent);font-weight:600;font-size:13.5px;padding:0}.auth-switch button:hover{text-decoration:underline}.boot{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:var(--text-3)}.boot .brand-mark{width:46px;height:46px;font-size:24px;animation:bootpulse 1.1s ease-in-out infinite}.boot span{font-size:14px}@keyframes bootpulse{0%,to{opacity:.5}50%{opacity:1}}.toast-host{position:fixed;left:50%;bottom:30px;transform:translate(-50%);z-index:90;display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none}.toast{display:flex;align-items:center;gap:9px;background:var(--text);color:#fff;padding:11px 18px;border-radius:11px;font-size:14px;font-weight:500;box-shadow:var(--shadow-lg);animation:toastIn .22s cubic-bezier(.2,.9,.3,1)}.toast svg{color:#6de18b}@keyframes toastIn{0%{opacity:0;transform:translateY(14px)}}@media(max-width:880px){.brand-txt span{display:none}.main{-webkit-overflow-scrolling:touch}.browse,.settings{padding:18px 16px 80px}.browse-head{flex-direction:column}.add-btn{height:46px}.search-input{height:48px}.grid-comfortable,.grid-compact{columns:2;column-gap:10px}.card{margin-bottom:10px}.drag-handle{display:none}.form-grid2,.role-pick{grid-template-columns:1fr}.emp-row{grid-template-columns:1.6fr auto;gap:8px 10px}.emp-row .emp-access,.emp-head,.user-txt{display:none}.hamburger{display:flex}.topcats-mobile{display:none}.sidebar{position:fixed;top:0;left:0;bottom:0;z-index:70;width:272px;max-width:84vw;flex:0 0 auto;padding:14px 12px;box-shadow:var(--shadow-lg);transform:translate(-100%);transition:transform .25s cubic-bezier(.4,0,.2,1)}.sidebar.sidebar-open{transform:translate(0)}.icon-btn.sidebar-close{display:grid}.sidebar-scrim{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:65;background:#141a286b;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fade .15s}.subtabs,.tagbar{flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-webkit-overflow-scrolling:touch;padding-bottom:4px}.subtabs::-webkit-scrollbar,.tagbar::-webkit-scrollbar{display:none}.subtab,.chip{flex:0 0 auto}.cat-subs{padding-left:6px}}@media(max-width:560px){.topbar{height:54px;flex:0 0 54px;padding:0 13px;gap:10px}.browse,.settings{padding:14px 12px 72px}.browse-head{margin-bottom:14px}.search-input{height:46px;font-size:15px}.add-btn{width:100%}.card{padding:11px;gap:8px;margin-bottom:9px}.card-title{font-size:14px}.card-cat{font-size:11px;padding:3px 7px}.card-answer{padding:9px;gap:7px}.card-text{font-size:13px;line-height:1.5}.copy-block{align-self:stretch;justify-content:center;width:100%}.copy-btn{height:32px;font-size:12.5px;padding:0 10px}.nav-pill span,.set-head p{display:none}.modal-scrim{padding:0;align-items:stretch}.modal{width:100%;max-width:100%;height:100%;border-radius:0;margin:0;display:flex;flex-direction:column}.modal-body{max-height:none;flex:1;min-height:0}.modal-foot{position:sticky;bottom:0}.confirm{width:100%;border-radius:var(--r-lg) var(--r-lg) 0 0;margin:auto 0 0}.detail-foot,.confirm-foot{flex-wrap:wrap}.set-tabs{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none}.set-tabs::-webkit-scrollbar{display:none}.set-tab{flex:0 0 auto}.toast-host{left:12px;right:12px;transform:none;bottom:18px}.toast{width:100%}}
