
/* ── MAIN CONTENT ── */
.content{padding:calc(var(--header-h) + 24px) 20px calc(var(--footer-h) + 24px);min-width:0;max-width:900px;margin:0 auto}
@media(max-width:920px){
  .content{padding-top:calc(var(--header-h) + 18px)}
}

.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:12px}
.page-title{font-family:'Playfair Display',serif;font-size:24px;font-weight:500;color:var(--ink);line-height:1.2}
.page-subtitle{font-size:13px;color:var(--ink-muted);margin-top:4px}

.export-btn{display:flex;align-items:center;gap:7px;padding:9px 16px;border-radius:var(--radius-sm);background:var(--ink);color:white;border:none;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}
.export-btn:hover{background:#2e2c28}
.export-btn svg{flex-shrink:0}

/* ── UPLOAD ZONE ── */
.upload-zone{border:2px dashed var(--border-strong);border-radius:var(--radius);padding:24px 20px;cursor:pointer;transition:all .2s;background:white;position:relative;margin-bottom:24px}
.upload-zone:hover,.upload-zone.drag-over{border-color:var(--gold);background:var(--gold-faint)}
.upload-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.upload-inner{display:flex;align-items:center;gap:14px;justify-content:center}
.upload-icon{width:40px;height:40px;background:var(--gold-faint);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.upload-title{font-size:14px;font-weight:500;margin-bottom:2px}
.upload-hint{font-size:12px;color:var(--ink-muted)}
.templates-help{background:var(--gold-faint);border:1px solid var(--border);border-radius:var(--radius);padding:14px 18px;margin-bottom:20px}
.templates-help-head{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--ink);margin-bottom:8px}
.templates-help-list{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:6px}
.templates-help-list li{font-size:12.5px;line-height:1.5;color:var(--ink-muted)}
.templates-help-list b{color:var(--ink);font-weight:600}

/* ── CATEGORIES ── */
.cats-section{}
.cats-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.cats-label{font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted)}
.add-cat-btn{display:flex;align-items:center;gap:5px;padding:5px 11px;border-radius:6px;border:1px solid var(--border-strong);background:white;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:500;color:var(--ink-muted);cursor:pointer;transition:all .15s}
.add-cat-btn:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-faint)}

/* ── CATEGORY GROUP ── */
.cat-group{margin-bottom:16px;border-radius:var(--radius);overflow:visible}
.cat-group.cat-dragging{opacity:.45}
.cat-group.cat-drag-over > .cat-group-header{box-shadow:0 -2px 0 var(--gold)}
.cat-drag-handle{color:var(--ink-faint);flex-shrink:0;cursor:grab;display:flex;align-items:center;opacity:.5;transition:opacity .13s}
.cat-group-header:hover .cat-drag-handle{opacity:1}
.cat-drag-handle:active{cursor:grabbing}
.cat-group-header{display:flex;align-items:center;gap:8px;padding:10px 14px;background:white;border:1px solid var(--border);border-radius:var(--radius-sm) var(--radius-sm) 0 0;border-bottom:none;position:relative;z-index:1}
.cat-group-header.collapsed{border-radius:var(--radius-sm);border-bottom:1px solid var(--border)}
.cat-color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;cursor:pointer}
.cat-name-input{flex:1;border:none;border-bottom:2px solid transparent;outline:none;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;color:var(--ink);background:transparent;cursor:pointer;min-width:0;padding-bottom:1px;transition:border-color .15s,background .15s;border-radius:0}
.cat-name-input:focus{cursor:text;border-bottom-color:var(--gold);background:linear-gradient(to bottom,transparent 90%,var(--gold-faint) 100%)}
.cat-name-input::placeholder{color:var(--ink-faint)}
.cat-name-input:not(:focus):hover{border-bottom-color:var(--border-strong)}
.cat-count{font-size:11px;color:var(--ink-faint);background:var(--cream);padding:2px 8px;border-radius:10px;flex-shrink:0}
.cat-collapse-btn{width:24px;height:24px;border-radius:5px;border:none;background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink-faint);transition:all .13s;flex-shrink:0}
.cat-collapse-btn:hover{background:var(--cream);color:var(--ink)}
.cat-collapse-btn svg{transition:transform .2s}
.cat-collapse-btn.collapsed svg{transform:rotate(-90deg)}
.cat-delete-btn{width:24px;height:24px;border-radius:5px;border:none;background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink-faint);transition:all .13s;flex-shrink:0;opacity:0}
.cat-group-header:hover .cat-delete-btn{opacity:1}
.cat-delete-btn:hover{background:#FBF0EE;color:var(--red)}
/* Tab number (small) + description (wide) inputs — replace the single name box */
.cat-num-input{width:48px;flex:0 0 48px;text-align:center;border:none;border-bottom:2px solid transparent;outline:none;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;color:var(--ink);background:transparent;cursor:pointer;min-width:0;padding-bottom:1px;transition:border-color .15s,background .15s;border-radius:0}
.cat-desc-input{flex:1;border:none;border-bottom:2px solid transparent;outline:none;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;color:var(--ink);background:transparent;cursor:pointer;min-width:0;padding-bottom:1px;transition:border-color .15s,background .15s;border-radius:0}
.cat-num-input:focus,.cat-desc-input:focus{cursor:text;border-bottom-color:var(--gold);background:linear-gradient(to bottom,transparent 90%,var(--gold-faint) 100%)}
.cat-num-input::placeholder,.cat-desc-input::placeholder{color:var(--ink-faint);font-weight:400}
.cat-num-input:not(:focus):hover,.cat-desc-input:not(:focus):hover{border-bottom-color:var(--border-strong)}

.cat-drop-zone{min-height:48px;border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius-sm) var(--radius-sm);background:white;transition:all .15s;padding:4px}
.cat-drop-zone.drag-target{background:var(--gold-faint);border-color:var(--gold);outline:2px solid rgba(184,150,90,.2)}
.cat-drop-zone.file-drop{border:2px dashed var(--gold);background:var(--gold-faint);outline:none}
.cat-group-header.drop-hover{background:var(--gold-faint);box-shadow:inset 0 0 0 2px var(--gold)}
.cat-drop-zone.empty{display:flex;align-items:center;justify-content:center;min-height:64px;cursor:pointer}
.cat-drop-zone.empty::after{content:'Drop files here, or click to upload — PDF, JPG, PNG, DOCX (25 MB)';font-size:12px;color:var(--ink-faint);pointer-events:none;text-align:center;padding:0 14px}
.cat-drop-zone.empty:hover{border-color:var(--gold);background:var(--gold-faint)}
.cat-drop-zone.empty:hover::after{color:var(--gold)}
.cat-drop-zone.empty.file-drop::after{content:'Drop to upload';color:var(--gold)}
.cat-group.collapsed .cat-drop-zone{display:none}

/* ── DOC ITEM ── */
.doc-item{display:flex;flex-wrap:wrap;align-items:center;gap:11px;padding:11px 14px;border-radius:7px;transition:all .15s;cursor:grab;background:white;margin-bottom:3px;border:1px solid transparent;user-select:none;-webkit-user-select:none}
.doc-item:last-child{margin-bottom:0}
.doc-item:hover{background:var(--gold-faint);border-color:rgba(184,150,90,.2)}
.doc-item.dragging{opacity:.4;cursor:grabbing}
.doc-item.drag-over-item{border-top:2px solid var(--gold)}
.doc-item.drag-over-item-below{border-bottom:2px solid var(--gold)}

.drag-handle{color:var(--ink-faint);flex-shrink:0;cursor:grab;display:flex;align-items:center}
.drag-handle:active{cursor:grabbing}

.doc-icon{width:34px;height:34px;border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:9px;font-weight:700;letter-spacing:.04em}
.doc-icon.pdf{background:#FBF0EE;color:var(--red)}
.doc-icon.img{background:var(--teal-light);color:var(--teal)}
.doc-icon.doc{background:#EEF2FB;color:#3A5FB8}
.doc-icon.txt{background:#F2F0FB;color:#5A4AB8}

.doc-info{flex:1;min-width:0}
.doc-name{font-size:13px;font-weight:500;color:var(--ink);white-space:pre-line;overflow-wrap:anywhere;cursor:text;border-radius:4px;padding:1px 5px;margin:-1px -5px;transition:background .12s,box-shadow .12s;outline:none;display:inline-block;max-width:100%}
.doc-name:hover{background:rgba(184,150,90,.10)}
.doc-name[contenteditable=true]{background:white;box-shadow:inset 0 0 0 1.5px var(--gold);white-space:pre-wrap;overflow:visible;text-overflow:clip;cursor:text}
.doc-meta{font-size:11px;color:var(--ink-faint);margin-top:1px;display:flex;align-items:center;gap:8px}

.translation-chip{font-size:10px;font-weight:500;color:var(--gold)}
.doc-action-btn{width:26px;height:26px;border-radius:5px;border:1px solid var(--border);background:white;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink-faint);transition:all .13s;flex-shrink:0}
.doc-action-btn:hover{border-color:var(--red);color:var(--red);background:#FBF0EE}
.doc-edit-btn{display:inline-flex;align-items:center;gap:5px;height:26px;padding:0 10px;border-radius:5px;border:1px solid var(--border);background:white;cursor:pointer;color:var(--ink-muted);font-family:'DM Sans',sans-serif;font-size:12px;font-weight:500;transition:all .13s;flex-shrink:0}
.doc-edit-btn:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-light)}
.doc-edit-btn svg{flex-shrink:0}
/* Attach Chinese-original companions: a button on the row + a full-width drop area */
.doc-companion-btn{display:inline-flex;align-items:center;gap:5px;height:26px;padding:0 10px;border-radius:5px;border:1px solid var(--border);background:white;cursor:pointer;color:var(--ink-muted);font-family:'DM Sans',sans-serif;font-size:12px;font-weight:500;transition:all .13s;flex-shrink:0;white-space:nowrap}
.doc-companion-btn svg{flex-shrink:0}
.doc-companion-btn:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-light)}
.doc-companion-btn.has{border-color:var(--teal);color:var(--teal);background:var(--teal-light)}
.doc-companion-area{flex-basis:100%;width:100%;margin-top:4px;padding:10px;border-top:1px dashed var(--border);display:flex;flex-direction:column;gap:8px}
.dca-list{display:flex;flex-wrap:wrap;gap:6px}
.dca-list:empty{display:none}
.dca-chip{display:inline-flex;align-items:center;gap:6px;max-width:280px;height:26px;padding:0 4px 0 8px;border-radius:6px;border:1px solid var(--border);background:var(--cream);font-size:11.5px;color:var(--ink)}
.dca-chip .dca-ic{font-size:8.5px;font-weight:700;color:var(--ink-faint);background:white;border:1px solid var(--border);border-radius:3px;padding:1px 3px;flex-shrink:0}
.dca-chip .dca-nm{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dca-chip .dca-remove{border:none;background:none;cursor:pointer;color:var(--ink-faint);font-size:16px;line-height:1;padding:0 2px;flex-shrink:0}
.dca-chip .dca-remove:hover{color:var(--red)}
.dca-drop{border:1.5px dashed var(--border);border-radius:6px;padding:12px;text-align:center;font-size:12px;color:var(--ink-faint);cursor:pointer;transition:all .13s}
.dca-drop:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-light)}
.dca-drop.over{border-color:var(--teal);background:var(--teal-light);color:var(--teal)}


.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:500;letter-spacing:.04em;flex-shrink:0}
.badge-dot{width:4px;height:4px;border-radius:50%;flex-shrink:0}
.badge.ready{background:#E8F5EC;color:#2D7A47}
.badge.ready .badge-dot{background:#2D7A47}
.badge.translated{background:var(--teal-light);color:var(--teal)}
.badge.translated .badge-dot{background:var(--teal)}
.badge.new{background:#FDEEDB;color:#B06A10}
.badge.new .badge-dot{background:#B06A10}
.badge.template{background:#EFEAF7;color:#7A5AB8}
.badge.template .badge-dot{background:#7A5AB8}
.processing-badge{display:flex;align-items:center;gap:5px;font-size:10px;color:var(--gold);font-weight:500;white-space:nowrap}
.processing-spinner{width:9px;height:9px;border:1.5px solid var(--gold-light);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes docIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}

/* ── COLOR PICKER POPOVER ── */
.color-popover{position:absolute;left:0;top:calc(100% + 6px);background:white;border:1px solid var(--border);border-radius:10px;padding:10px;display:flex;gap:7px;flex-wrap:wrap;width:152px;box-shadow:0 4px 20px rgba(0,0,0,.12);z-index:100}
.color-swatch{width:22px;height:22px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:transform .12s}
.color-swatch:hover{transform:scale(1.15)}
.color-swatch.selected{border-color:var(--ink)}

/* ── MARKETPLACE MODAL ── */
.modal-backdrop{display:none;position:fixed;inset:0;background:rgba(26,25,22,.5);z-index:300;align-items:flex-end;justify-content:center}
.modal-backdrop.open{display:flex}
.modal{background:white;border-radius:20px 20px 0 0;padding:24px 20px 36px;width:100%;max-width:500px;animation:slideUp .25s ease;max-height:85vh;overflow-y:auto}
@keyframes slideUp{from{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal-handle{width:36px;height:4px;background:var(--border-strong);border-radius:2px;margin:0 auto 20px}
.modal-title{font-family:'Playfair Display',serif;font-size:20px;font-weight:500;margin-bottom:4px}
.modal-sub{font-size:13px;color:var(--ink-muted);margin-bottom:20px}

/* Module marketplace cards */
.mkt-grid{display:flex;flex-direction:column;gap:10px}
.mkt-card{display:flex;align-items:flex-start;gap:14px;padding:16px;border:1px solid var(--border);border-radius:var(--radius-sm);transition:all .15s;position:relative}
.mkt-card:hover{border-color:var(--gold-light);background:var(--gold-faint)}
.mkt-card-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.mkt-card-body{flex:1;min-width:0}
.mkt-card-name{font-size:14px;font-weight:500;color:var(--ink);margin-bottom:3px}
.mkt-card-desc{font-size:12px;color:var(--ink-muted);line-height:1.4}
.mkt-card-price{font-size:11px;font-weight:500;color:var(--ink-faint);margin-top:5px}
.mkt-badge{position:absolute;top:12px;right:12px;font-size:10px;font-weight:500;padding:2px 8px;border-radius:10px}
.mkt-badge.soon{background:#F2F1EE;color:var(--ink-faint)}
.mkt-badge.active{background:#E8F5EC;color:#2D7A47}
.subscribe-btn{margin-top:8px;padding:7px 14px;border-radius:6px;border:1px solid var(--border-strong);background:white;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:500;color:var(--ink-muted);cursor:pointer;transition:all .15s}
.subscribe-btn:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-faint)}
.subscribe-btn.installed{background:var(--cream);color:var(--ink-faint);cursor:default;border-color:var(--border)}
