:root{
  --bg:#f6f7f9;
  --card:#ffffff;
  --accent:#0b3d91;
  --muted:#6b7280;
  --radius:8px;
  --font:'Times New Roman',Times,serif;
  --internal-sidebar-width:250px;
  --juno-min-width:1200px;
  --juno-min-height:760px;
}
*{box-sizing:border-box}
html,body{min-width:var(--juno-min-width);min-height:var(--juno-min-height);}
body{font-family:var(--font);background:var(--bg);color:#0f1724;margin:0}
button,input,select,textarea,option,optgroup{font-family:var(--font);}
.btn,.um-btn,.icon-btn,.docs-btn,.um-action-btn,.app-page-btn,.app-page-size{font-family:var(--font);}
.container{max-width:980px;margin:36px auto;padding:20px}
.header{display:flex;align-items:center;justify-content:space-between;padding:12px 0}
.logo{font-weight:700;color:var(--accent);font-size:20px}
.main{margin-top:28px}
.card{background:var(--card);padding:28px;border-radius:var(--radius);box-shadow:0 6px 18px rgba(12,18,29,0.06);max-width:420px}
h1{font-size:26px;margin:0 0 8px}
h2{font-size:20px;margin:0 0 12px}
.lead{color:var(--muted);margin:8px 0 20px}
.actions{display:flex;gap:12px;margin-top:18px}
.btn{background:var(--accent);color:#fff;padding:0 14px;height:38px;min-width:112px;border-radius:8px;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid transparent;font-weight:600;line-height:1;cursor:pointer;white-space:nowrap}
.btn.outline{background:transparent;color:var(--accent);border:1px solid rgba(11,61,145,0.2)}
.btn-icon{display:inline-flex;align-items:center;justify-content:center;font-size:13px;line-height:1}
.btn-with-icon{display:inline-flex;align-items:center;justify-content:center;gap:6px}
.field{display:flex;flex-direction:column;margin:10px 0}
.field label{font-size:13px;color:var(--muted);margin-bottom:6px}
.field input{padding:10px;border-radius:8px;border:1px solid #e6e9ef}
.muted{color:var(--muted);font-size:13px;margin-top:12px}
.footer{color:var(--muted);font-size:13px;margin-top:32px}

/* Auth login page (Juno Capital Portal style) */
.auth-page{min-height:100vh;background:#031b4c;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.auth-hero{position:fixed;inset:0;background-size:cover;background-position:center left;transform:scale(1.03);}
.auth-overlay{position:fixed;inset:0;background:linear-gradient(120deg, rgba(10,25,52,0.68), rgba(10,25,52,0.32) 50%, rgba(10,25,52,0.12));}
.auth-container{position:relative;z-index:2;width:100%;display:flex;justify-content:flex-end;align-items:center;padding:64px 80px;}
.auth-card{width:460px;background:rgba(255,255,255,0.96);border-radius:18px;padding:32px 34px 28px;box-shadow:0 30px 80px rgba(8,16,40,0.28);backdrop-filter:blur(6px);}
.auth-logo{display:flex;align-items:center;gap:14px;color:#1c2b4f;margin-bottom:18px;}
.auth-logo img{height:44px;width:auto;display:block;}
.auth-brand{display:flex;align-items:baseline;gap:6px;}
.brand-main{font-weight:600;color:#1c2b4f;font-size:19px;}
.brand-sub{font-weight:600;color:#c89c3a;font-size:19px;}
.auth-card h2{font-size:17px;margin:4px 0 18px;color:#2f3a4c;text-align:center;font-weight:600;letter-spacing:0.2px;}
.auth-error{color:#b42318;font-size:13px;text-align:center;margin-bottom:10px;}
.auth-form{display:flex;flex-direction:column;gap:12px;}
.auth-field label{font-size:12px;color:#7b8190;margin-bottom:6px;display:block;}
.auth-input{display:flex;align-items:center;gap:10px;border:1px solid #e1e6ee;border-radius:8px;padding:11px 12px;background:#fff;box-shadow:inset 0 1px 2px rgba(10,20,40,0.05);}
.auth-input .icon{font-size:16px;color:#97a0b2;}
.auth-input input{border:none;outline:none;width:100%;font-size:14px;background:transparent;color:#1f2937;}
.auth-options{display:flex;align-items:center;justify-content:flex-start;margin-top:2px;}
.remember{font-size:13px;color:#6b7280;display:flex;align-items:center;gap:8px;}
.auth-button{margin-top:14px;background:linear-gradient(90deg,#2f63dd,#1c4fbf);color:#fff;border:none;border-radius:8px;padding:13px 16px;font-weight:600;cursor:pointer;box-shadow:0 10px 18px rgba(25,60,150,0.22);}
.auth-divider{height:1px;background:#e5e7eb;margin:18px 0 12px;}
.auth-footer{text-align:center;font-size:13px;color:#6a7282;}
.auth-footer a{color:#6a7282;text-decoration:none;}
.auth-footer a:hover{text-decoration:underline;}

/* Internal dashboard mockup */
.internal-page{margin:0;font-family:var(--font);background:#f3f4f8;color:#1f2a44;height:100vh;overflow:hidden;}
.internal-layout{display:flex;height:100vh;min-height:100vh;overflow:hidden;}
.internal-page,.internal-layout{min-width:var(--juno-min-width);min-height:var(--juno-min-height);}
.internal-sidebar{
  width:var(--internal-sidebar-width);
  min-width:var(--internal-sidebar-width);
  max-width:var(--internal-sidebar-width);
  flex:0 0 var(--internal-sidebar-width);
  height:100vh;
  overflow-y:auto;
  overflow-x:hidden;
  color:#fff;
  background-size:cover;
  background-position:bottom center;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  padding:22px 18px;
  position:relative;
}
.internal-sidebar:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(12,29,66,0.9) 0%, rgba(12,29,66,0.75) 55%, rgba(12,29,66,0.95) 100%);} 
.internal-sidebar > *{position:relative;z-index:1;}
.sidebar-logo{display:flex;align-items:center;justify-content:center;margin:-22px -18px 16px;padding:0;}
.sidebar-logo img{width:100%;height:auto;display:block;}
.sidebar-nav{display:flex;flex-direction:column;gap:8px;margin-top:0;flex:1;}
.nav-item{color:#e5e7eb;text-decoration:none;padding:10px 12px;border-radius:8px;display:flex;align-items:center;gap:8px;font-size:14px;}
.nav-item .dot{display:none}
.nav-item .nav-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;margin-right:10px;color:#cbd5f5;font-size:18px}
.nav-item > .nav-icon{order:0}
.nav-item > span{order:1}
.nav-item .nav-icon svg{width:20px;height:20px}

/* keep submenu icons smaller than top-level */
.nav-subitem .nav-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;margin-right:8px;color:#cbd5f5;font-size:14px}
.nav-subitem .nav-icon svg{width:16px;height:16px}
.nav-item.active{background:linear-gradient(90deg,#c59a34,#e3b55c);color:#1c2b4f;font-weight:600;}
.nav-group{display:flex;flex-direction:column;gap:6px;}
.nav-caret{margin-left:auto;font-size:12px;transition:transform .18s ease;color:#cbd5f5;}
.nav-submenu{display:none;flex-direction:column;gap:6px;padding-left:18px;}
.nav-subitem{color:#e5e7eb;text-decoration:none;padding:8px 12px;border-radius:8px;font-size:13px;display:flex;align-items:center;gap:8px;}
.nav-subitem:hover{background:rgba(255,255,255,0.08);}
.nav-subitem.active{background:rgba(255,255,255,0.14);font-weight:600;}
.nav-group.open .nav-submenu{display:flex;}
.nav-group.open .nav-caret{transform:rotate(180deg);}
.sidebar-footer{font-size:11px;color:#d1d5db;text-align:left;opacity:0.8;padding-top:10px;margin-top:auto;}

/* small icon for submenu items (left of label) */
.nav-subitem .nav-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;margin-right:8px;color:#cbd5f5}
.nav-subitem > .nav-icon{order:0}
.nav-subitem > span{order:1}
.nav-subitem .nav-icon svg{width:16px;height:16px;display:block}

.internal-main{flex:1 1 auto;min-width:0;height:100vh;display:flex;flex-direction:column;overflow:hidden;}
.internal-topbar{position:sticky;top:0;z-index:40;flex-shrink:0;display:flex;justify-content:space-between;align-items:center;padding:14px 22px;background:#f8f9fd;border-bottom:1px solid #e6e9f2;}
.internal-main > main{flex:1 1 auto;min-height:0;overflow:auto;}
.topbar-left{display:flex;align-items:center;gap:12px;}
.search{background:#fff;border:1px solid #e2e6ee;border-radius:8px;padding:6px 10px;min-width:260px;}
.search input{border:none;outline:none;width:100%;font-size:13px;}
.topbar-right{display:flex;align-items:center;gap:10px;}
.icon-btn{background:#fff;border:1px solid #e2e6ee;border-radius:8px;padding:6px 8px;cursor:pointer;}
.logout-btn{padding:6px 10px;font-size:12px;font-weight:600;color:#1f2a44;text-decoration:none;}
.user-chip{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #e2e6ee;border-radius:999px;padding:4px 10px;}
.user-chip .avatar{background:#2f63dd;color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;}
.user-chip .name{font-size:13px;color:#1f2a44;}
.is-readonly-disabled{pointer-events:none;opacity:0.55;filter:grayscale(0.05);cursor:not-allowed;}
.is-readonly-disabled[aria-disabled="true"]{cursor:not-allowed;}

.juno-topbar-tools{display:flex;align-items:center;gap:10px;}
.juno-tool-btn{background:#fff;border:1px solid #d9dfec;border-radius:12px;color:#1f2a44;min-height:40px;display:inline-flex;align-items:center;justify-content:center;font-weight:700;cursor:pointer;position:relative}
.juno-tool-btn:hover{background:#f7f9ff;border-color:#c6d2eb}
.juno-tool-assistant{padding:0;min-width:42px;font-size:18px;line-height:1}
.juno-tool-btn.icon-only{width:42px;min-width:42px;padding:0;font-size:18px}
.juno-tool-btn[data-tooltip]:hover::after{
  content:attr(data-tooltip);
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  top:calc(100% + 8px);
  background:#111827;
  color:#fff;
  font-size:12px;
  line-height:1;
  font-weight:600;
  padding:6px 8px;
  border-radius:6px;
  white-space:nowrap;
  z-index:10;
  pointer-events:none;
}

.juno-window-layer{position:fixed;inset:0;z-index:2500;pointer-events:none}
.juno-window{position:fixed;min-width:560px;min-height:360px;background:#fff;border:1px solid #b9c7e5;border-radius:12px;box-shadow:0 28px 70px rgba(15,23,42,0.25);resize:both;overflow:hidden;pointer-events:auto}
.juno-window.is-maximized{resize:none;border-radius:10px}
.juno-window.is-minimized{height:auto !important;min-height:0}
.juno-window.is-minimized .juno-window-body{display:none}
.juno-window-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;background:linear-gradient(180deg,#f8fbff,#edf3ff);border-bottom:1px solid #d7e1f3;cursor:move;user-select:none}
.juno-window-title{font-size:14px;font-weight:700;color:#1f2a44}
.juno-window-controls{display:flex;align-items:center;gap:6px}
.juno-window-control{width:28px;height:24px;border:1px solid #ced7eb;border-radius:6px;background:#fff;color:#334155;font-size:14px;cursor:pointer;line-height:1}
.juno-window-control:hover{background:#f4f7ff}
.juno-window-control.danger{color:#b42318}
.juno-window-body{height:calc(100% - 48px);overflow:auto;background:#fbfdff}

.juno-ai-panel,.juno-email-panel,.juno-email-draft-panel{display:flex;flex-direction:column;height:100%}
.juno-window-toolbar{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#fff;border-bottom:1px solid #e5ebf6}
.juno-window-toolbar label{font-size:13px;color:#475569;font-weight:600}
.juno-window-toolbar select{height:36px;border:1px solid #cfd8ea;border-radius:8px;padding:0 10px;min-width:260px;max-width:100%}
.juno-mini-btn{height:34px;border:1px solid #cbd5e8;border-radius:8px;background:#fff;color:#1f2a44;padding:0 12px;font-weight:600;cursor:pointer}
.juno-mini-btn:hover:not(:disabled){background:#f2f6ff}
.juno-mini-btn:disabled{opacity:0.6;cursor:not-allowed}
.juno-mini-btn.primary{background:#1f3a70;border-color:#1f3a70;color:#fff}

.juno-chat-log{flex:1;overflow:auto;padding:12px;background:linear-gradient(180deg,#f8fbff,#f4f7fe)}
.juno-chat-row{display:flex;margin-bottom:10px}
.juno-chat-row.user{justify-content:flex-end}
.juno-chat-bubble{max-width:min(760px,85%);padding:10px 12px;border-radius:10px;background:#fff;border:1px solid #d8e2f3;color:#1f2a44;font-size:14px;line-height:1.45;white-space:pre-wrap;word-break:break-word}
.juno-chat-row.user .juno-chat-bubble{background:#1f3a70;color:#fff;border-color:#1f3a70}
.juno-chat-bubble.pending{background:#ecf2ff;border-color:#cddbf6;color:#334155}
.juno-inline-image{display:block;max-width:min(100%,380px);max-height:380px;border-radius:8px;border:1px solid #d9e3f5;background:#fff}
.ai-chat-image-name{margin-top:6px;font-size:12px;color:#64748b;line-height:1.3;word-break:break-all}
.juno-chat-compose{display:flex;flex-direction:column;gap:10px;padding:12px;background:#fff;border-top:1px solid #e5ebf6}
.juno-chat-input{width:100%;min-height:90px;max-height:240px;resize:vertical;border:1px solid #cfd8ea;border-radius:10px;padding:10px 12px;font-size:14px;color:#1f2a44}
.juno-chat-actions{display:flex;justify-content:flex-end;gap:8px}
.juno-chat-actions select{height:34px;border:1px solid #cfd8ea;border-radius:8px;padding:0 10px;background:#fff;color:#1f2a44}
.da-ai-left-actions{display:flex;align-items:center;gap:8px;margin-right:auto;flex-wrap:wrap}
.da-ai-attach-toolbar{position:relative;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.da-ai-attachments{display:flex;align-items:center;gap:8px;flex-wrap:wrap;min-height:24px}
.da-ai-attachment-empty{font-size:12px;color:#64748b}
.da-ai-attachment-chip{display:inline-flex;align-items:center;gap:6px;border:1px solid #d7e1f3;background:#f8fbff;border-radius:999px;padding:3px 8px;max-width:320px}
.da-ai-attachment-type{font-size:10px;font-weight:700;color:#1d4ed8;background:#e8f0ff;border-radius:999px;padding:1px 6px}
.da-ai-attachment-name{font-size:12px;color:#334155;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:220px}
.da-ai-attachment-remove{border:none;background:transparent;color:#64748b;font-size:14px;line-height:1;cursor:pointer;padding:0 2px}
.da-ai-db-picker{position:absolute;left:0;top:40px;width:min(520px,92vw);max-height:320px;border:1px solid #ced9ed;border-radius:10px;background:#fff;box-shadow:0 16px 40px rgba(15,23,42,.16);z-index:8;display:flex;flex-direction:column;overflow:hidden}
.da-ai-db-search{height:36px;border:none;border-bottom:1px solid #e2e8f4;padding:0 10px;font-size:13px;color:#1f2a44;outline:none}
.da-ai-db-results{max-height:280px;overflow:auto;display:flex;flex-direction:column}
.da-ai-db-item{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;text-align:left;border:none;border-bottom:1px solid #edf2fb;background:#fff;padding:9px 10px;cursor:pointer}
.da-ai-db-item:hover:not(:disabled){background:#f5f8ff}
.da-ai-db-item:disabled{cursor:not-allowed;opacity:.55}
.da-ai-db-file{font-size:13px;color:#1f2a44;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.da-ai-db-version{font-size:11px;color:#64748b}
.da-ai-db-empty{padding:10px;color:#64748b;font-size:12px}

.juno-window-status{min-height:20px;padding:8px 12px 0;color:#64748b;font-size:13px}
.juno-window-status[data-type="error"]{color:#b42318}
.juno-window-status[data-type="info"]{color:#1d4ed8}

.da-viewer-panel{display:flex;flex-direction:column;height:100%}
.da-viewer-meta{font-size:13px;font-weight:700;color:#334155;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.da-viewer-toolbar{display:flex;align-items:center;gap:8px;margin-left:auto}
.da-viewer-content{flex:1;min-height:0;background:#fff}
.da-summary-panel{display:flex;flex-direction:column;height:100%}
.da-summary-body{flex:1;min-height:0;overflow:auto;padding:10px 12px;background:#fff}
.da-summary-sections{display:flex;flex-direction:column;gap:10px}
.da-summary-sections section h4{margin:0 0 6px;color:#334155;font-size:13px;font-weight:700}
.da-loading{display:flex;align-items:center;justify-content:center;color:#64748b;font-size:14px}
.da-text-preview{margin:0;padding:14px;font-size:13px;line-height:1.5;color:#1f2a44;background:#fff;white-space:pre-wrap;word-break:break-word;height:100%;overflow:auto}
.da-preview-frame{width:100%;height:100%;border:none;background:#fff}
.da-image-wrap{display:flex;align-items:center;justify-content:center;width:100%;height:100%;padding:16px;overflow:auto;background:#f8fafc}
.da-preview-image{max-width:100%;max-height:100%;object-fit:contain;border:1px solid #d9e3f5;border-radius:8px;background:#fff;box-shadow:0 8px 20px rgba(15,23,42,.08)}
.da-preview-error{display:flex;align-items:center;justify-content:center;color:#b42318;background:#fff7f6;font-size:14px;padding:12px}
.da-docx-wrap{height:100%;overflow:auto;background:#f3f4f8;padding:22px}
.da-docx-preview{max-width:860px;margin:0 auto;background:#fff;border:1px solid #d9e1ee;border-radius:10px;padding:30px 34px;box-shadow:0 10px 28px rgba(15,23,42,.08);color:#1f2937;line-height:1.7}
.da-docx-preview p{margin:0 0 12px;font-size:14px}
.da-docx-preview h3{margin:16px 0 10px;font-size:18px;line-height:1.3;color:#1f2a44}
.da-docx-table{width:100%;border-collapse:collapse;margin:8px 0 14px}
.da-docx-table td{border:1px solid #d9e2f0;padding:7px 9px;font-size:13px;vertical-align:top}
.da-excel-preview{display:flex;flex-direction:column;height:100%;background:#fff}
.da-excel-tabs{display:flex;align-items:center;gap:8px;overflow:auto;padding:10px 12px;border-bottom:1px solid #e4eaf6;background:#f8fafc}
.da-excel-tab{height:32px;padding:0 12px;border:1px solid #d3dcee;border-radius:8px;background:#fff;color:#334155;font-weight:600;cursor:pointer;white-space:nowrap}
.da-excel-tab.active{background:#1f3a70;color:#fff;border-color:#1f3a70}
.da-excel-sheet{flex:1;min-height:0}
.da-excel-table-wrap{height:100%;overflow:auto}
.da-excel-table{width:max-content;min-width:100%;border-collapse:collapse}
.da-excel-table th,.da-excel-table td{border:1px solid #e2e8f4;padding:6px 10px;font-size:13px;line-height:1.45;vertical-align:top;white-space:nowrap}
.da-excel-table th{position:sticky;top:0;background:#f3f6fd;color:#334155;font-weight:700;z-index:1}
.da-excel-empty{text-align:center;color:#64748b}

.juno-email-grid{display:grid;grid-template-columns:repeat(2,minmax(220px,1fr));gap:10px;padding:12px;background:#fff;border-bottom:1px solid #e5ebf6}
.juno-email-grid label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#475569}
.juno-email-grid input{height:36px;border:1px solid #cfd8ea;border-radius:8px;padding:0 10px}
.juno-email-row{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#fff;border-bottom:1px solid #e5ebf6}
.juno-email-row.full{display:flex;flex-direction:column;align-items:stretch}
.juno-email-row label{font-size:13px;color:#475569;font-weight:600;min-width:96px}
.juno-email-row select,.juno-email-row input{height:36px;border:1px solid #cfd8ea;border-radius:8px;padding:0 10px;flex:1}
.juno-email-row textarea{width:100%;min-height:220px;resize:vertical;border:1px solid #cfd8ea;border-radius:10px;padding:10px 12px;font-size:14px}
.juno-email-actions{display:flex;justify-content:flex-end;padding:10px 12px 14px;background:#fff}

.juno-rich-source{display:none !important}
.juno-rich-editor{width:100%;border:1px solid #cfd8ea;border-radius:10px;background:#fff;overflow:hidden}
.juno-rich-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:8px 10px;border-bottom:1px solid #e5ebf6;background:#f8fbff}
.juno-rich-toolbar-label{font-size:12px;color:#475569;font-weight:700}
.juno-rich-toolbar select{height:30px;border:1px solid #cfd8ea;border-radius:8px;padding:0 8px;background:#fff;color:#1f2a44;min-width:140px}
.juno-rich-toolbar input[type="color"]{width:34px;height:30px;border:1px solid #cfd8ea;border-radius:8px;padding:2px;background:#fff}
.juno-rich-btn{height:30px;min-width:30px;border:1px solid #cfd8ea;border-radius:8px;background:#fff;color:#1f2a44;padding:0 8px;cursor:pointer;font-size:12px;line-height:1}
.juno-rich-btn:hover{background:#f1f5ff}
.juno-rich-content{min-height:220px;padding:10px 12px;outline:none;overflow:auto;line-height:1.5;word-break:break-word;white-space:pre-wrap;font-size:13px;color:#1f2a44}
.juno-rich-content:empty::before{content:attr(data-placeholder);color:#94a3b8}
.juno-rich-inline-image{display:block;max-width:min(100%,520px);max-height:320px;margin:8px 0;border:1px solid #d9e3f5;border-radius:8px;background:#fff}
.juno-rich-hint{padding:6px 10px;border-top:1px solid #e5ebf6;background:#fcfdff;color:#64748b;font-size:11px}

.juno-email-draft-panel{padding:10px;background:#fff}
.juno-draft-prompt-label,.juno-draft-result-label{font-size:13px;color:#475569;font-weight:600;margin-top:8px;margin-bottom:6px}
.juno-draft-prompt,.juno-draft-result{width:100%;border:1px solid #cfd8ea;border-radius:10px;padding:10px 12px;font-size:14px;resize:vertical}
.juno-draft-actions{display:flex;justify-content:flex-end;gap:8px;padding-top:8px}
.juno-draft-actions label{font-size:13px;color:#475569;font-weight:600}
.juno-draft-actions select{height:34px;border:1px solid #cfd8ea;border-radius:8px;padding:0 10px;background:#fff;color:#1f2a44}
.juno-draft-image-preview{margin-top:10px;padding:10px;border:1px solid #d9e3f5;border-radius:10px;background:#f8fbff}
.juno-draft-image{display:block;max-width:100%;max-height:300px;margin:0 auto;border:1px solid #dbe4f3;border-radius:8px;background:#fff}

.juno-user-editor{display:flex;flex-direction:column;height:100%;background:#fff}
.juno-user-tabs{display:flex;gap:8px;padding:10px 12px;border-bottom:1px solid #e5ebf6;background:#fff}
.juno-user-tab{height:34px;padding:0 12px;border:1px solid #d5deee;border-radius:8px;background:#fff;color:#334155;font-weight:600;cursor:pointer}
.juno-user-tab.active{background:#eaf1ff;border-color:#bcd0f3;color:#1f3a70}
.juno-user-tab-panel{display:none;padding:12px;overflow:auto}
.juno-user-tab-panel.active{display:block}
.juno-user-form-grid{display:grid;grid-template-columns:repeat(2,minmax(220px,1fr));gap:10px}
.juno-user-form-grid label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#475569}
.juno-user-form-grid input,.juno-user-form-grid select{height:36px;border:1px solid #cfd8ea;border-radius:8px;padding:0 10px}
.juno-user-section{margin-top:12px}
.juno-user-section h4{margin:0 0 8px;font-size:14px;color:#334155}
.juno-user-role-list{display:flex;flex-wrap:wrap;gap:8px;padding:4px 0}
.juno-user-role-pill{display:inline-flex;align-items:center;height:26px;padding:0 10px;border-radius:999px;background:#ecf2ff;color:#1f3a70;font-size:12px;font-weight:600;border:1px solid #d2def8}
.juno-user-role-empty{color:#64748b;font-size:13px}
.juno-user-permission-table{width:100%;border-collapse:collapse;background:#fff}
.juno-user-permission-table th,.juno-user-permission-table td{padding:9px 7px;border-bottom:1px solid #ebeff7;text-align:left;font-size:12px}
.juno-user-permission-table th{font-size:12px;color:#475569}
.juno-user-permission-table select{height:34px;border:1px solid #cfd8ea;border-radius:8px;padding:0 10px;background:#fff}
.juno-user-actions{display:flex;justify-content:flex-end;gap:8px;padding:10px 12px 14px;border-top:1px solid #e5ebf6;background:#fff}

@media (max-width: 900px){
  .juno-topbar-tools{gap:6px}
  .juno-tool-assistant{min-width:132px}
  .juno-window{left:8px !important;top:8px !important;width:calc(100vw - 16px) !important;height:calc(100vh - 16px) !important;min-width:0}
  .juno-email-grid{grid-template-columns:1fr}
  .juno-user-form-grid{grid-template-columns:1fr}
}

.dashboard{padding:22px;display:flex;flex-direction:column;gap:18px;}
.welcome h2{margin:0;font-size:20px;}
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.kpi-card{background:#fff;border-radius:12px;padding:16px;box-shadow:0 8px 20px rgba(15,23,42,0.05);}
.kpi-title{font-size:12px;color:#64748b;margin-bottom:6px;}
.kpi-value{font-size:20px;font-weight:700;color:#1f2a44;}

.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.panel{background:#fff;border-radius:12px;padding:16px;box-shadow:0 8px 20px rgba(15,23,42,0.05);}
.panel-header{font-size:14px;font-weight:600;margin-bottom:12px;color:#1f2a44;}
.panel-body{display:flex;flex-direction:column;gap:10px;}
.panel.wide{grid-column:span 3;}
.chart.donut{width:140px;height:140px;border-radius:50%;background:conic-gradient(#284b8f 0 30%, #d8a64a 30% 55%, #1f3a70 55% 80%, #cbd5e1 80% 100%);margin:0 auto;}
.legend{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px;font-size:12px;color:#64748b;}
.legend-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:6px;}
.legend-dot.blue{background:#284b8f;}
.legend-dot.gold{background:#d8a64a;}
.legend-dot.navy{background:#1f3a70;}
.legend-dot.gray{background:#cbd5e1;}
.activity{font-size:13px;color:#334155;background:#f8fafc;border-radius:8px;padding:8px 10px;}
.btn.small{align-self:flex-start;background:#d8a64a;color:#1f2a44;border:none;border-radius:8px;padding:8px 12px;font-weight:600;}
.btn.add{align-self:flex-start;background:#1f3a70;color:#fff;border:none;border-radius:8px;padding:8px 12px;font-weight:600;}
.bar-chart{height:180px;background:linear-gradient(180deg,#f1f5f9,#ffffff);border-radius:10px;}

@media (max-width: 1200px){
  .kpi-row{grid-template-columns:repeat(2,1fr);} 
  .grid{grid-template-columns:1fr;} 
  .panel.wide{grid-column:span 1;} 
}

@media (max-width: 900px){
  .internal-page{
    height:100vh;
    overflow:auto;
  }
  .internal-layout{
    flex-direction:row;
    height:100vh;
    min-height:var(--juno-min-height);
    overflow:hidden;
  }
  .internal-sidebar{
    width:var(--internal-sidebar-width);
    min-width:var(--internal-sidebar-width);
    max-width:var(--internal-sidebar-width);
    flex-basis:var(--internal-sidebar-width);
    height:100vh;
    overflow-y:auto;
    overflow-x:hidden;
    flex-direction:column;
    align-items:stretch;
    gap:0;
  }
  .sidebar-nav{
    flex-direction:column;
    flex-wrap:nowrap;
  }
  .internal-main{
    height:100vh;
    overflow:hidden;
  }
  .internal-topbar{position:sticky;}
  .internal-main > main{overflow:auto;}
}

@media (max-width: 900px){
  .auth-container{justify-content:center;padding:24px;}
  .auth-card{width:100%;max-width:440px;}
}

.um-header h2{margin:0;font-size:24px;font-weight:700;color:#1f2a44;}
.internal-sidebar .nav-item span, .internal-sidebar .nav-subitem, .um-header h2, .um-scope-tabs a, .um-table th { text-transform: capitalize; }
.um-scope-tabs{background:#eef3f8;border-radius:14px;padding:12px 18px 28px;display:flex;gap:12px;align-items:center;box-shadow:inset 0 1px 0 rgba(255,255,255,0.6), 0 6px 20px rgba(12,18,29,0.04);} 
.um-scope-tabs a{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:10px;text-decoration:none;color:#445066;font-size:14px;font-weight:600;border:1px solid rgba(12,18,29,0.06);transition:transform .14s,box-shadow .14s,background-color .14s,color .14s;backface-visibility:hidden;background:linear-gradient(180deg,#fbfdff,#f1f6fa);box-shadow:0 4px 10px rgba(12,18,29,0.04);} 
.um-scope-tabs a:hover,.um-scope-tabs a:focus{color:#0f2438;background:linear-gradient(180deg,#ffffff,#eef6fb);transform:translateY(-6px);box-shadow:0 18px 40px rgba(12,18,29,0.12);} 
.um-scope-tabs a.active{color:#0b2033;background:#ffffff;transform:translateY(-8px);box-shadow:0 28px 60px rgba(12,18,29,0.18);position:relative;font-weight:800;z-index:3;border-color:rgba(12,18,29,0.08);} 
.um-scope-tabs a.active::after{content:'';position:absolute;left:10px;right:10px;bottom:-12px;height:6px;background:linear-gradient(90deg,#d8a64a,#c5973a);border-radius:6px;box-shadow:0 6px 20px rgba(216,166,74,0.18);} 

.um-card{background:#fff;border-radius:12px;box-shadow:0 8px 20px rgba(15,23,42,0.05);overflow:hidden;}
.um-filters{display:flex;align-items:center;gap:10px;padding:16px;border-bottom:1px solid #eceff5;background:#f8f9fd;flex-wrap:wrap;}
.um-filters input[type="text"],.um-filters select{width:auto;max-width:100%;padding:10px 12px;border:1px solid #d9deea;border-radius:8px;background:#fff;color:#1f2a44;}
.um-filters input[type="text"]{flex:1 1 360px;min-width:180px;}
.um-filters .btn.add{margin-left:auto;}

.um-table-wrap{overflow:auto;}
.um-table{width:100%;border-collapse:collapse;min-width:900px;}
.um-table th,.um-table td{padding:9px 10px;border-bottom:1px solid #edf0f6;text-align:left;font-size:12px;color:#1f2a44;}
.um-table th{font-weight:600;background:#f8f9fd;white-space:nowrap;}

/* Row hover and selected state */
.um-table tbody tr{transition:background-color .12s,transform .12s;}
.um-table tbody tr:hover td{background:linear-gradient(90deg,#fbfdff,#f7fbff);}
.um-table tbody tr.selected{transform:translateY(-1px);} 
.um-table tbody tr.selected td{background:linear-gradient(90deg,#eef9ff,#eaf6ff);} 
/* visual left indicator (dot) for selected row */
.um-table tbody tr.selected td:first-child{position:relative;padding-left:22px;} 
.um-table tbody tr.selected td:first-child::before{content:'';position:absolute;left:8px;top:50%;transform:translateY(-50%);width:10px;height:10px;background:linear-gradient(90deg,#d8a64a,#c5973a);border-radius:50%;box-shadow:0 6px 18px rgba(216,166,74,0.18);} 

/* placeholder empty rows to maintain visual height */
.um-empty-row td{height:48px;background:transparent;border-bottom:1px solid #edf0f6;}
/* visual left indicator (dot) for selected row */
.um-table tbody tr.selected td:first-child{position:relative;padding-left:22px;} 
.um-table tbody tr.selected td:first-child::before{content:'';position:absolute;left:8px;top:50%;transform:translateY(-50%);width:10px;height:10px;background:linear-gradient(90deg,#d8a64a,#c5973a);border-radius:50%;box-shadow:0 6px 18px rgba(216,166,74,0.18);} 

.um-user-link,.um-action-btn{border:none;background:transparent;color:#23417e;cursor:pointer;font-weight:600;padding:0;}
.um-action-btn{padding:0 10px;min-height:34px;min-width:88px;border-radius:8px;border:1px solid #d5daea;background:#fff;color:#1f2a44;font-weight:500;display:inline-flex;align-items:center;justify-content:center;gap:6px;line-height:1;}
.um-user-link:hover,.um-action-btn:hover{text-decoration:underline;}

.doc-cat-status{display:inline-flex;align-items:center;justify-content:center;width:10px;height:10px;border-radius:50%;margin-right:8px;background:#cbd5e1;box-shadow:0 0 0 2px rgba(15,23,42,0.06)}
.doc-cat-status.is-active{background:#22c55e}
.doc-cat-status.is-inactive{background:#f97316}
.doc-cat-status.is-deleted{background:#9ca3af}
.doc-cat-row-deleted{opacity:0.55}

.doc-cat-action{border:1px solid #d5daea;background:#fff;color:#1f2a44;border-radius:8px;padding:6px 8px;margin-right:6px;cursor:pointer;min-height:32px;min-width:36px;display:inline-flex;align-items:center;justify-content:center;line-height:1}
.doc-cat-action:last-child{margin-right:0}
.doc-cat-action[disabled]{opacity:0.45;cursor:not-allowed}

.doc-cat-extensions-field{display:flex;flex-direction:column;align-items:flex-start;gap:8px}
.doc-cat-extensions-display{font-size:12px;color:#64748b;line-height:1.35;min-height:16px}
.doc-cat-extensions-options{display:grid;grid-template-columns:repeat(2,minmax(180px,1fr));gap:8px 14px;max-height:280px;overflow:auto;padding:4px 2px}
.doc-cat-extensions-option{display:flex;align-items:center;gap:8px;font-size:14px;color:#1f2a44}
.doc-cat-extensions-option code{font-size:12px;color:#334155;background:#f1f5f9;padding:1px 6px;border-radius:6px}

/* Resource Data page specific button consistency */
#tab-resource .btn,
#tab-resource .um-btn,
#tab-resource .um-action-btn{border-radius:8px}

#tab-resource .resource-actions .btn,
#tab-resource .resource-filters .btn,
#tab-resource .resource-pagination-row .btn,
#tab-resource #translations-panel .btn{min-width:118px;height:38px}

#tab-resource .resource-toolbar{padding:12px 16px 10px;border-bottom:1px solid #eceff5;background:#fff;display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
#tab-resource .resource-heading-line{display:flex;flex-direction:column;gap:4px;min-width:0}
#tab-resource .resource-title{margin:0;font-size:16px;font-weight:700;color:#1f2a44;line-height:1.2}
#tab-resource .resource-subtitle{margin:0;color:#64748b;font-size:12px;line-height:1.25}
#tab-resource .resource-actions{display:flex;align-items:center;gap:6px;margin-left:auto;flex-wrap:nowrap;justify-content:flex-end}

#tab-resource .resource-actions .btn{min-width:84px;height:32px;padding:0 10px;font-size:13px;gap:5px}
#tab-resource .resource-actions .btn .btn-icon{font-size:12px}

/* hide duplicated middle import controls while keeping input usable for top Import button */
#tab-resource .resource-import-form{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}

/* pagination: smaller text and controls aligned to far right */
#tab-resource .resource-pagination-row{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-top:1px solid #eceff5}
#tab-resource #resource-info{font-size:13px;color:#64748b}
#tab-resource .resource-pagination-row > div:last-child{margin-left:auto;display:flex;align-items:center;gap:6px}
#tab-resource #resource-page{font-size:14px;color:#334155;min-width:16px;text-align:center;display:inline-block}

@media (max-width: 1200px){
  #tab-resource .resource-toolbar{flex-wrap:wrap;align-items:flex-start}
  #tab-resource .resource-heading-line{width:100%}
  #tab-resource .resource-actions{width:100%;justify-content:flex-start}
}

#tab-resource .resource-pagination-row .btn,
#tab-resource #translations-panel #trans-panel-prev,
#tab-resource #translations-panel #trans-panel-next{min-width:108px}

#tab-resource .resource-pagination-row .btn{min-width:96px;height:34px;padding:0 10px;font-size:13px}

#tab-value-lists .btn,
#tab-value-items .btn,
#tab-value-lists .um-btn,
#tab-value-items .um-btn,
#tab-value-lists .um-action-btn,
#tab-value-items .um-action-btn{border-radius:8px}

#tab-value-lists .resource-actions .btn,
#tab-value-items .resource-actions .btn,
#tab-value-lists .resource-filters .btn,
#tab-value-items .resource-filters .btn,
#tab-value-lists .resource-pagination-row .btn,
#tab-value-items .resource-pagination-row .btn{min-width:96px;height:34px;padding:0 10px;font-size:13px}

#tab-value-lists .resource-toolbar,
#tab-value-items .resource-toolbar{padding:12px 16px 10px;border-bottom:1px solid #eceff5;background:#fff;display:flex;align-items:flex-start;justify-content:space-between;gap:12px}

#tab-value-lists .resource-heading-line,
#tab-value-items .resource-heading-line{display:flex;flex-direction:column;gap:4px;min-width:0}

#tab-value-lists .resource-title,
#tab-value-items .resource-title{margin:0;font-size:16px;font-weight:700;color:#1f2a44;line-height:1.2}

#tab-value-lists .resource-subtitle,
#tab-value-items .resource-subtitle{margin:0;color:#64748b;font-size:12px;line-height:1.25}

#tab-value-lists .resource-actions,
#tab-value-items .resource-actions{display:flex;align-items:center;gap:6px;margin-left:auto;flex-wrap:nowrap;justify-content:flex-end}

#tab-value-lists .resource-actions .btn,
#tab-value-items .resource-actions .btn{min-width:84px;height:32px;padding:0 10px;font-size:13px;gap:5px}

#tab-value-lists .resource-actions .btn .btn-icon,
#tab-value-items .resource-actions .btn .btn-icon{font-size:12px}

#tab-value-lists .resource-pagination-row,
#tab-value-items .resource-pagination-row{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-top:1px solid #eceff5}

#tab-value-lists #value-lists-info,
#tab-value-items #value-items-info{font-size:13px;color:#64748b}

#tab-value-lists .resource-pagination-row > div:last-child,
#tab-value-items .resource-pagination-row > div:last-child{margin-left:auto;display:flex;align-items:center;gap:6px}

#tab-value-lists #value-lists-page,
#tab-value-items #value-items-page{font-size:14px;color:#334155;min-width:16px;text-align:center;display:inline-block}

#tab-smtp-config .btn,
#tab-smtp-config .um-btn,
#tab-smtp-config .um-action-btn{border-radius:8px}

#tab-smtp-config .resource-actions .btn,
#tab-smtp-config .resource-filters .btn,
#tab-smtp-config .resource-pagination-row .btn{min-width:96px;height:34px;padding:0 10px;font-size:13px}

#tab-smtp-config .resource-toolbar{padding:12px 16px 10px;border-bottom:1px solid #eceff5;background:#fff;display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
#tab-smtp-config .resource-heading-line{display:flex;flex-direction:column;gap:4px;min-width:0}
#tab-smtp-config .resource-title{margin:0;font-size:16px;font-weight:700;color:#1f2a44;line-height:1.2}
#tab-smtp-config .resource-subtitle{margin:0;color:#64748b;font-size:12px;line-height:1.25}
#tab-smtp-config .resource-actions{display:flex;align-items:center;gap:6px;margin-left:auto;flex-wrap:nowrap;justify-content:flex-end}
#tab-smtp-config .resource-actions .btn{min-width:84px;height:32px;padding:0 10px;font-size:13px;gap:5px}
#tab-smtp-config .resource-actions .btn .btn-icon{font-size:12px}

#tab-smtp-config .resource-pagination-row{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-top:1px solid #eceff5}
#tab-smtp-config #smtp-config-info{font-size:13px;color:#64748b}
#tab-smtp-config .resource-pagination-row > div:last-child{margin-left:auto;display:flex;align-items:center;gap:6px}
#tab-smtp-config #smtp-config-page{font-size:14px;color:#334155;min-width:16px;text-align:center;display:inline-block}
#tab-smtp-config .icon-only{position:relative}
#tab-smtp-config .icon-only[data-tooltip]:hover::after{
  content:attr(data-tooltip);
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  bottom:calc(100% + 6px);
  background:#1f2a44;
  color:#fff;
  padding:3px 7px;
  border-radius:6px;
  font-size:11px;
  line-height:1;
  white-space:nowrap;
  pointer-events:none;
  z-index:10;
}

#tab-ai-credentials .btn,
#tab-ai-credentials .um-btn,
#tab-ai-credentials .um-action-btn,
#tab-ai-models .btn,
#tab-ai-models .um-btn,
#tab-ai-models .um-action-btn,
#tab-ai-chat .btn,
#tab-ai-chat .um-btn,
#tab-ai-chat .um-action-btn{border-radius:8px}

#tab-ai-credentials .resource-actions .btn,
#tab-ai-credentials .resource-filters .btn,
#tab-ai-credentials .resource-pagination-row .btn,
#tab-ai-models .resource-actions .btn,
#tab-ai-models .resource-filters .btn,
#tab-ai-models .resource-pagination-row .btn,
#tab-ai-chat .resource-actions .btn{min-width:96px;height:34px;padding:0 10px;font-size:13px}

#tab-ai-credentials .resource-toolbar,
#tab-ai-models .resource-toolbar,
#tab-ai-chat .resource-toolbar{padding:12px 16px 10px;border-bottom:1px solid #eceff5;background:#fff;display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
#tab-ai-credentials .resource-heading-line,
#tab-ai-models .resource-heading-line,
#tab-ai-chat .resource-heading-line{display:flex;flex-direction:column;gap:4px;min-width:0}
#tab-ai-credentials .resource-title,
#tab-ai-models .resource-title,
#tab-ai-chat .resource-title{margin:0;font-size:16px;font-weight:700;color:#1f2a44;line-height:1.2}
#tab-ai-credentials .resource-subtitle,
#tab-ai-models .resource-subtitle,
#tab-ai-chat .resource-subtitle{margin:0;color:#64748b;font-size:12px;line-height:1.25}
#tab-ai-credentials .resource-actions,
#tab-ai-models .resource-actions,
#tab-ai-chat .resource-actions{display:flex;align-items:center;gap:6px;margin-left:auto;flex-wrap:nowrap;justify-content:flex-end}
#tab-ai-credentials .resource-actions .btn,
#tab-ai-models .resource-actions .btn,
#tab-ai-chat .resource-actions .btn{min-width:84px;height:32px;padding:0 10px;font-size:13px;gap:5px}
#tab-ai-credentials .resource-actions .btn .btn-icon,
#tab-ai-models .resource-actions .btn .btn-icon,
#tab-ai-chat .resource-actions .btn .btn-icon{font-size:12px}

#tab-ai-credentials .resource-pagination-row,
#tab-ai-models .resource-pagination-row{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-top:1px solid #eceff5}
#tab-ai-credentials .resource-pagination-row > div:last-child,
#tab-ai-models .resource-pagination-row > div:last-child{margin-left:auto;display:flex;align-items:center;gap:6px}
#tab-ai-credentials .icon-only,
#tab-ai-models .icon-only{position:relative}
#tab-ai-credentials .icon-only[data-tooltip]:hover::after,
#tab-ai-models .icon-only[data-tooltip]:hover::after{
  content:attr(data-tooltip);
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  bottom:calc(100% + 6px);
  background:#1f2a44;
  color:#fff;
  padding:3px 7px;
  border-radius:6px;
  font-size:11px;
  line-height:1;
  white-space:nowrap;
  pointer-events:none;
  z-index:10;
}

#tab-ai-chat{
  display:flex;
  flex-direction:column;
}

.ai-chat-controls{
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 16px;
  border-bottom:1px solid #eceff5;
  background:#f8f9fd;
}

.ai-chat-controls label{
  font-size:13px;
  color:#475569;
  font-weight:600;
  white-space:nowrap;
}

.ai-chat-controls select{
  flex:1;
  height:38px;
  border:1px solid #cfd8ea;
  border-radius:8px;
  padding:0 10px;
  color:#1f2a44;
  background:#fff;
  min-width:220px;
}

.ai-chat-window{
  min-height:420px;
  max-height:520px;
  overflow:auto;
  padding:16px;
  background:linear-gradient(180deg,#f8fbff 0%,#f5f7fc 100%);
  border-bottom:1px solid #eceff5;
}

.ai-chat-row{
  display:flex;
  margin-bottom:10px;
}

.ai-chat-row.user{
  justify-content:flex-end;
}

.ai-chat-bubble{
  max-width:min(780px, 86%);
  border-radius:12px;
  padding:10px 12px;
  line-height:1.45;
  font-size:14px;
  color:#1f2a44;
  background:#ffffff;
  border:1px solid #dde5f2;
  box-shadow:0 2px 8px rgba(15,23,42,0.04);
  white-space:pre-wrap;
  word-break:break-word;
}

.ai-chat-row.user .ai-chat-bubble{
  background:#1f3a70;
  border-color:#1f3a70;
  color:#ffffff;
}

.ai-chat-bubble.pending{
  background:#ecf2ff;
  color:#334155;
  border-color:#cfdcf7;
}

.ai-chat-status{
  min-height:20px;
  padding:8px 16px 0;
  color:#64748b;
  font-size:13px;
}

.ai-chat-status[data-type="error"]{
  color:#b42318;
}

.ai-chat-composer{
  display:flex;
  align-items:flex-end;
  gap:10px;
  padding:12px 16px 16px;
  background:#fff;
}

.ai-chat-composer textarea{
  flex:1;
  min-height:86px;
  max-height:220px;
  resize:vertical;
  border:1px solid #cfd8ea;
  border-radius:10px;
  padding:10px 12px;
  font-size:14px;
  color:#1f2a44;
  line-height:1.4;
}

.ai-chat-composer textarea:disabled{
  background:#f2f4f8;
  color:#94a3b8;
}

.ai-chat-actions{
  display:flex;
  align-items:center;
  gap:8px;
}

.ai-chat-actions select{
  height:38px;
  border:1px solid #cfd8ea;
  border-radius:8px;
  padding:0 10px;
  background:#fff;
  color:#1f2a44;
}

@media (max-width: 1200px){
  #tab-value-lists .resource-toolbar,
  #tab-value-items .resource-toolbar,
  #tab-smtp-config .resource-toolbar,
  #tab-ai-credentials .resource-toolbar,
  #tab-ai-models .resource-toolbar,
  #tab-ai-chat .resource-toolbar{flex-wrap:wrap;align-items:flex-start}
  #tab-value-lists .resource-heading-line,
  #tab-value-items .resource-heading-line,
  #tab-smtp-config .resource-heading-line,
  #tab-ai-credentials .resource-heading-line,
  #tab-ai-models .resource-heading-line,
  #tab-ai-chat .resource-heading-line{width:100%}
  #tab-value-lists .resource-actions,
  #tab-value-items .resource-actions,
  #tab-smtp-config .resource-actions,
  #tab-ai-credentials .resource-actions,
  #tab-ai-models .resource-actions,
  #tab-ai-chat .resource-actions{width:100%;justify-content:flex-start}
}

/* Small action icons in table buttons */
#tab-resource .um-action-btn[data-action="edit"]::before,
#tab-resource .um-action-btn[data-action="trans-edit"]::before,
#tab-resource .um-action-btn[data-action="transpanel-edit"]::before,
#tab-resource .um-action-btn[data-action="trans-save"]::before,
#tab-resource .um-action-btn[data-action="transpanel-save"]::before{content:'✎';font-size:12px;line-height:1}

#tab-resource .um-action-btn[data-action="delete"]::before,
#tab-resource .um-action-btn[data-action="trans-delete"]::before,
#tab-resource .um-action-btn[data-action="transpanel-delete"]::before{content:'🗑';font-size:12px;line-height:1}

#tab-resource .um-action-btn[data-action="translations"]::before{content:'🌐';font-size:12px;line-height:1}

#tab-resource .um-action-btn[data-action="transpanel-cancel"]::before,
#tab-resource .um-action-btn[data-action="trans-cancel"]::before,
#tab-resource .um-action-btn[data-action="transpanel-add-cancel"]::before{content:'↩';font-size:12px;line-height:1}

#tab-resource .um-action-btn[data-action="transpanel-add-save"]::before{content:'＋';font-size:12px;line-height:1}
.um-actions{position:relative;display:inline-block;}
.um-action-menu{position:absolute;top:34px;right:0;min-width:220px;background:#1e2a50;border-radius:12px;padding:8px 8px 6px;box-shadow:0 20px 40px rgba(12,18,29,0.32);z-index:50;overflow:visible}
.um-action-menu::before{content:'';position:absolute;top:-8px;right:26px;width:14px;height:14px;background:#1e2a50;transform:rotate(45deg);box-shadow:0 6px 14px rgba(12,18,29,0.12);border-radius:2px}
.um-action-item{display:block;width:100%;text-align:left;border:none;background:transparent;color:#fff;font-size:15px;padding:14px 14px 14px 52px;border-radius:8px;cursor:pointer;position:relative}
.um-action-item:hover{background:linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.02));}
.um-action-item[disabled]{opacity:0.45;cursor:not-allowed}

/* icons for action items (using unicode fallbacks) */
.um-action-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:20px;height:20px;display:inline-block}
.um-action-icon svg{width:20px;height:20px;display:block}
.um-action-item .um-action-icon svg{stroke:currentColor;fill:none}

/* map default icon color; last child will invert colors via rules below */
.um-action-item{color:#fff}
.um-action-item .um-action-icon{color:rgba(255,255,255,0.95)}

/* last item white background and dark icon */
.um-action-item:last-child{background:#fff;color:#1f2a44;border-radius:0 0 10px 10px;margin-top:6px}
.um-action-item:last-child .um-action-icon{color:#1f2a44}
.um-action-item:last-child:hover{background:#f6f8fb}

/* small adjustment for narrow menus */
@media (max-width:480px){
  .um-action-menu{right:6px;left:6px;min-width:auto}
  .um-action-menu::before{right:40px}
}

.status-pill{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-weight:600;font-size:12px;}
.status-pill.active{background:#e7f3e8;color:#2e6240;}
.status-pill.disabled{background:#f8e9e9;color:#a13b3b;}

.um-pagination{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;}
.um-page-links{display:flex;align-items:center;gap:8px;}
.um-page-links a,.um-page-links span{padding:6px 10px;border-radius:8px;text-decoration:none;border:1px solid #e1e6f0;color:#334155;background:#fff;}
.um-page-links a.current{background:#1f3a70;color:#fff;border-color:#1f3a70;}
.um-page-links .disabled{opacity:0.5;}

.um-modal[hidden]{display:none;}
.um-modal{position:fixed;inset:0;z-index:1000;}
.um-modal-backdrop{position:absolute;inset:0;background:rgba(10,20,40,0.45);}
.um-modal-panel{position:relative;z-index:1;max-width:900px;width:92%;max-height:90vh;overflow:auto;margin:5vh auto;background:#fff;border-radius:14px;box-shadow:0 24px 80px rgba(10,20,40,0.35);}
.um-notice-panel{max-width:520px;}
.um-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #e8ecf5;}
.um-modal-header h3{margin:0;color:#1f2a44;}
.um-close{border:none;background:transparent;font-size:26px;line-height:1;cursor:pointer;color:#64748b;}

.um-modal-tabs{display:flex;gap:10px;padding:10px 20px;border-bottom:1px solid #e8ecf5;}
.um-tab{border:none;background:#edf1f9;color:#1f2a44;padding:8px 14px;border-radius:8px;cursor:pointer;font-weight:600;}
.um-tab.active{background:#1f3a70;color:#fff;}

.um-modal-content{padding:16px 20px;}
.um-tab-panel{display:none;}
.um-tab-panel.active{display:block;}
.um-form-grid{display:grid;grid-template-columns:repeat(2,minmax(220px,1fr));gap:12px;}
.um-form-grid label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#475569;}
.um-form-grid input,.um-form-grid select{padding:10px 12px;border:1px solid #d8deec;border-radius:8px;background:#fff;font-size:14px;}
.sysparam-sections{display:flex;flex-direction:column;gap:14px}
.sysparam-section{border:1px solid #e2e8f0;border-radius:10px;padding:12px;background:#fbfdff}
.sysparam-section h4{margin:0 0 10px 0;font-size:14px;font-weight:700;color:#1f2a44}
.um-role-grid{display:grid;grid-template-columns:repeat(3,minmax(180px,1fr));gap:8px 14px;margin-bottom:12px}
.um-role-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border:1px solid #e5eaf4;border-radius:8px;background:#fff;font-size:13px;color:#334155}
.um-role-item input{margin:0}

/* Custom searchable select styles */
.um-select{position:relative;width:100%;}
.um-select-display{width:100%;padding:10px 12px;border:1px solid #d8deec;border-radius:8px;background:#fff;cursor:text;min-height:44px;display:block;font-size:14px;color:#1f2a44}
.um-select-display:focus{outline:none;border-color:#9bb0de;box-shadow:0 0 0 2px rgba(47,99,221,0.12)}
.um-select-dropdown{position:absolute;left:0;right:0;top:52px;background:#fff;border:1px solid rgba(13,30,60,0.06);border-radius:8px;box-shadow:0 10px 30px rgba(16,24,40,0.12);z-index:30;padding:8px;max-height:230px;overflow:auto}
.um-select-search{width:100%;padding:8px 10px;border-radius:6px;border:1px solid #eef2f7;margin-bottom:8px}
.um-select-options{list-style:none;padding:0;margin:0;max-height:180px;overflow:auto}
.um-select-options li{padding:8px 10px;border-radius:6px;cursor:pointer;color:#1f2a44}
.um-select-options li:hover{background:#f1f6ff}
.um-select-options li.selected{background:linear-gradient(90deg,#eef9ff,#eaf6ff);font-weight:600}

/* Small screens adjustments */
@media (max-width: 600px){
  .um-select-dropdown{top:60px}
}

.um-permission-table{width:100%;border-collapse:collapse;}

.um-permission-table th,.um-permission-table td{padding:9px 7px;border-bottom:1px solid #edf0f6;text-align:left;font-size:12px;}
.um-permission-table th{font-size:12px;color:#475569;}

.um-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:14px 20px;border-top:1px solid #e8ecf5;}
.um-btn{border:none;padding:10px 16px;border-radius:8px;cursor:pointer;font-weight:600;}
.um-btn.secondary{background:#e9edf6;color:#334155;}
.um-btn.primary{background:#1f3a70;color:#fff;}

.um-no-scroll{overflow:hidden;}

.ai-config-tabs{display:flex;gap:10px;padding:14px 16px;background:#f8f9fd;border-bottom:1px solid #eceff5}
.ai-config-panel{display:none}
.ai-config-panel.active{display:block}

@media (max-width: 900px){
  .um-scope-tabs a{font-size:14px;}
  .um-header h2{font-size:22px;}
  .um-form-grid{grid-template-columns:1fr;}
  .um-role-grid{grid-template-columns:1fr;}
  .ai-chat-controls{flex-direction:column;align-items:stretch;}
  .ai-chat-composer{flex-direction:column;align-items:stretch;}
  .ai-chat-actions{flex-wrap:wrap;}
  .ai-chat-actions select{width:100%;}
  .ai-chat-composer .btn{width:100%;}
}

/* Documents module */
.docs-page{gap:14px}
.docs-header h2{margin:0;font-size:42px;color:#1f2a44;font-weight:700;letter-spacing:.2px}
.docs-card{background:rgba(255,255,255,.92);border:1px solid #e8ecf5;border-radius:12px;box-shadow:0 16px 35px rgba(16,24,40,.07);overflow:hidden}
.docs-filters{display:flex;gap:10px;align-items:center;padding:14px;background:#f7f8fd;border-bottom:1px solid #e8ecf5;flex-wrap:wrap}
.docs-filters input,.docs-filters select{padding:10px 12px;border:1px solid #d9deea;border-radius:8px;background:#fff;color:#1f2a44;min-width:140px}
.docs-filters input{flex:1 1 280px}
.docs-filters .btn.add{margin-left:auto}
.docs-table-wrap{overflow:auto}
.docs-table{width:100%;border-collapse:collapse;min-width:980px}
.docs-table th,.docs-table td{padding:9px 8px;border-bottom:1px solid #eceff6;text-align:left;font-size:12px;color:#1f2a44;vertical-align:top}
.docs-table th{background:#f8f9fd;font-weight:600;white-space:nowrap}
.docs-link{color:#233f7b;text-decoration:none;font-weight:600}
.docs-link:hover{text-decoration:underline}
.docs-actions{display:flex;gap:6px;flex-wrap:wrap}
.docs-actions .um-btn{padding:6px 10px;font-size:12px}
.docs-pagination{display:flex;align-items:center;justify-content:center;gap:14px;padding:14px}
.docs-subtitle{margin:16px 0 10px;color:#1f2a44}
.docs-principal-table{width:100%;border-collapse:collapse}
.docs-principal-table th,.docs-principal-table td{padding:7px 6px;border-bottom:1px solid #eef2f8;font-size:12px;text-align:left}
.docs-principal-table select,.docs-principal-table input[type="text"]{padding:8px 10px;border:1px solid #d8deec;border-radius:8px;width:100%}
.docs-principal-picker{display:flex;gap:8px}
.docs-modal-panel{max-width:1080px}
.docs-tabs{display:flex;gap:6px;padding:10px;background:#f8f9fd;border-bottom:1px solid #e8ecf5}
.docs-tab{border:none;background:#eceff8;color:#1f2a44;padding:8px 12px;border-radius:8px;cursor:pointer;font-weight:600}
.docs-tab.active{background:#1f3a70;color:#fff}
.docs-tab-panel{display:none;padding:16px}
.docs-tab-panel.active{display:block}
.docs-kv-grid{display:grid;grid-template-columns:repeat(4,minmax(180px,1fr));gap:10px}
.docs-kv{padding:10px;border:1px solid #e7ebf4;border-radius:8px;background:#fafbff}
.docs-kv span{display:block;font-size:12px;color:#64748b;margin-bottom:4px}
.docs-kv strong{font-size:14px;color:#1f2a44}
.docs-actions-line{display:flex;gap:10px;justify-content:flex-end;margin-top:14px}

@media (max-width: 1024px){
  .docs-kv-grid{grid-template-columns:repeat(2,minmax(180px,1fr))}
}
@media (max-width: 700px){
  .docs-kv-grid{grid-template-columns:1fr}
  .docs-actions-line{justify-content:flex-start;flex-wrap:wrap}
}

/* Inline and row-level error message styles */
.row-error{color:#b42318;font-size:12px;margin-top:6px}
.inline-msg{color:#b42318;font-size:13px;margin-top:6px}
/* Button loading state */
.um-action-btn.loading,.btn.loading,.um-btn.loading{opacity:0.7;pointer-events:none;position:relative}
.um-action-btn.loading::after,.btn.loading::after,.um-btn.loading::after{content:'';position:absolute;right:10px;top:50%;transform:translateY(-50%);width:14px;height:14px;border:2px solid rgba(255,255,255,0.6);border-top-color:transparent;border-radius:50%;animation:spin 0.9s linear infinite}
@keyframes spin{from{transform:translateY(-50%) rotate(0deg)}to{transform:translateY(-50%) rotate(360deg)}}
/* fade animation for inline messages */
.row-error,.inline-msg{transition:opacity .28s ease,transform .28s ease}

/* Toast styles */
.um-toast{background:#111827;color:#fff;padding:10px 14px;border-radius:8px;margin-top:8px;box-shadow:0 10px 30px rgba(2,6,23,0.4);opacity:0;transform:translateY(-6px);transition:opacity .28s,transform .28s;font-size:13px}
/* toast variants */
.um-toast-success{background:#10b981;color:#fff}
.um-toast-info{background:#2563eb;color:#fff}
.um-toast-error{background:#ef4444;color:#fff}

/* toast icon */
.um-toast .um-toast-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;margin-right:8px;flex:0 0 20px}
.um-toast .um-toast-icon svg{width:16px;height:16px;display:block;stroke:currentColor;fill:none}
.um-toast .um-toast-message{display:inline-block;vertical-align:middle}

/* Documents v1 - visual style aligned with product mock */
.docs-v1{--docs-bg:#f4f6fb;--docs-card:#fdfdff;--docs-border:#e2e8f3;--docs-text:#1f2a44;--docs-muted:#6b7280;--docs-blue:#1f3f82;--docs-gold:#d8a72c}
.docs-v1 .dashboard{background:var(--docs-bg)}
.docs-v1-page{gap:12px}
.docs-v1-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.docs-title-actions{display:flex;align-items:center;gap:10px}
.docs-return-icon{width:22px;height:22px;display:inline-block;vertical-align:middle;fill:currentColor;margin-right:0;transform:translateY(-1px)}
.docs-return-btn span{display:inline-block;vertical-align:middle}
.docs-return-btn{
  /* keep size from .docs-btn but make visually prominent */
  background:linear-gradient(180deg,#fff7e4,#ffffff 60%);
  color:var(--docs-blue);
  border-color:rgba(216,167,44,0.65);
  font-weight:800;
  box-shadow:0 12px 26px rgba(15,23,42,0.12), 0 0 0 1px rgba(216,167,44,0.25);
  border-radius:10px;
  transition:transform .12s ease,box-shadow .12s ease,background-color .12s ease,color .12s ease;
  min-width:36px;
  gap:0;
}
.docs-return-btn:hover{
  transform:translateY(-3px);
  box-shadow:0 20px 44px rgba(15,23,42,0.16), 0 0 0 1px rgba(216,167,44,0.35);
}
.docs-return-btn:active{
  transform:translateY(0);
  box-shadow:0 10px 20px rgba(15,23,42,0.12), 0 0 0 1px rgba(216,167,44,0.25);
}
.docs-v1-title-row h2{margin:0;font-size:20px;line-height:1.2;font-weight:700;color:var(--docs-text);letter-spacing:0}
.docs-v1-card{background:var(--docs-card);border:1px solid var(--docs-border);border-radius:14px;overflow:hidden;box-shadow:0 10px 28px rgba(16,24,40,.08)}

.docs-v1-filters{display:grid;grid-template-columns:minmax(240px,2fr) repeat(6,minmax(120px,1fr));gap:10px;padding:14px;border-bottom:1px solid var(--docs-border);background:linear-gradient(180deg,#fafbff,#f6f8fd)}
.docs-v1-filters input,.docs-v1-filters select{height:40px;border:1px solid #d4dcec;border-radius:8px;padding:0 12px;font-size:14px;color:#24314f;background:#fff;outline:none}
.docs-v1-filters input:focus,.docs-v1-filters select:focus{border-color:#98acd9;box-shadow:0 0 0 2px rgba(47,99,221,0.12)}

.docs-v1-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-bottom:1px solid var(--docs-border);background:#fff}
.docs-v1-info{font-size:13px;color:var(--docs-muted);font-weight:500}

.docs-btn{height:36px;padding:0 14px;border-radius:8px;border:1px solid transparent;font-size:14px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap}
.docs-btn-sm{height:30px;padding:0 10px;font-size:12px;font-weight:600}
.docs-btn-blue{background:var(--docs-blue);color:#fff;border-color:var(--docs-blue)}
.docs-btn-gold{background:var(--docs-gold);color:#1f2a44;border-color:var(--docs-gold)}
.docs-btn-ghost{background:#f4f6fb;color:#27324d;border-color:#dde4f0}
.docs-btn-danger{background:#fff;color:#b42318;border-color:#f0c9c5}
.docs-btn:disabled{opacity:.55;cursor:not-allowed}

/* Ensure the Return button appears visually prominent even when using the
   shared "ghost" modifier — make the combined selector more specific so
   these styles win over the generic .docs-btn-ghost rule. Keeps size intact. */
.docs-return-btn.docs-btn-ghost{
  background:linear-gradient(180deg,#fff7e4,#ffffff 60%);
  color:var(--docs-blue);
  border-color:rgba(216,167,44,0.65);
  font-weight:800;
  box-shadow:0 12px 26px rgba(15,23,42,0.12), 0 0 0 1px rgba(216,167,44,0.25);
  border-radius:10px;
}
.docs-return-btn.docs-btn-ghost:hover{
  transform:translateY(-3px);
  box-shadow:0 20px 44px rgba(15,23,42,0.16), 0 0 0 1px rgba(216,167,44,0.35);
}
.docs-return-btn.docs-btn-ghost:active{
  transform:translateY(0);
  box-shadow:0 10px 20px rgba(15,23,42,0.12), 0 0 0 1px rgba(216,167,44,0.25);
}

.docs-v1-table-wrap{overflow:auto}
.docs-v1-table{width:100%;border-collapse:collapse;min-width:1080px}
.docs-v1-table th,.docs-v1-table td{padding:9px 8px;border-bottom:1px solid #e7edf8;text-align:left;color:#27324d;font-size:12px;vertical-align:top}
.docs-v1-table th{font-size:11px;font-weight:800;letter-spacing:.02em;color:#3a4660;background:#f6f8fd;white-space:nowrap}
.docs-v1-table tbody tr:hover td{background:#fbfcff}
.docs-link{color:#1f3f82;text-decoration:none;font-weight:800;line-height:1.2}
.docs-link:hover{text-decoration:underline}

.docs-v1-pagination{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 14px;background:#fff}
#docs-page-label{min-width:16px;text-align:center;font-size:13px;color:#4a5568;font-weight:700}

.status-pill{display:inline-flex;align-items:center;padding:5px 11px;border-radius:999px;font-size:12px;font-weight:700;line-height:1}
.status-pill.active{background:#dff2e8;color:#2f6d4a}
.status-pill.disabled{background:#f6e7e8;color:#b54747}
.status-pill.draft{background:#faece8;color:#b5472c}
.status-pill.archived{background:#ebeef5;color:#5b6478}

.docs-action-group{position:relative;display:flex;gap:6px;align-items:center}
.docs-action-menu{position:absolute;right:0;top:34px;z-index:25;min-width:188px;background:#fff;border:1px solid #dbe3f0;border-radius:10px;box-shadow:0 18px 34px rgba(15,23,42,.18);padding:6px}
.docs-action-menu-item{display:block;width:100%;text-align:left;background:#fff;border:none;border-radius:8px;padding:8px 10px;color:#24314f;font-size:13px;cursor:pointer}
.docs-action-menu-item:hover{background:#f3f7ff}
.analyst-actions-cell{min-width:210px}
.analyst-actions{display:flex;align-items:center;gap:8px}
.analyst-icon-btn{
  position:relative;
  width:34px;
  height:30px;
  border:1px solid #d6deef;
  border-radius:8px;
  background:#f5f7fc;
  color:#24314f;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  font-size:15px;
  line-height:1;
}
.analyst-icon-btn:hover:not(:disabled){
  border-color:#9fb0d8;
  background:#ecf1fb;
}
.analyst-icon-btn.is-disabled,
.analyst-icon-btn:disabled{
  opacity:.5;
  cursor:not-allowed;
}
.analyst-icon-btn[data-tooltip]:hover::after{
  content:attr(data-tooltip);
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  bottom:calc(100% + 8px);
  background:#111827;
  color:#fff;
  font-size:12px;
  font-weight:600;
  line-height:1.25;
  padding:6px 8px;
  border-radius:6px;
  white-space:nowrap;
  z-index:35;
  box-shadow:0 8px 20px rgba(15,23,42,0.25);
  pointer-events:none;
}
.analyst-snapshot-badge{
  margin-top:5px;
  font-size:11px;
  padding:4px 9px;
}

.docs-modal-panel-v1{max-width:920px;width:94%;border-radius:14px}
.docs-modal-content-v1{background:#fbfcff}
.docs-modal-subtitle{margin:14px 0 8px;font-size:13px;color:#5b6478}
.docs-form-grid{display:grid;grid-template-columns:repeat(2,minmax(180px,1fr));gap:10px}
.docs-form-grid label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#475569;font-weight:600}
.docs-form-grid input,.docs-form-grid select{height:38px;border:1px solid #d5deed;border-radius:8px;padding:0 10px;background:#fff;font-size:14px;color:#1f2a44}
.docs-mini-table{width:100%;border-collapse:collapse;margin-bottom:10px}
.docs-mini-table th,.docs-mini-table td{padding:7px 6px;border-bottom:1px solid #e8edf7;text-align:left;font-size:12px;color:#24314f}

/* legacy audit table */
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:9px 10px;border-bottom:1px solid #edf0f6;text-align:left;font-size:12px;color:#1f2a44;vertical-align:top}
.table th{font-weight:600;background:#f8f9fd;white-space:nowrap}
.docs-principal-picker{display:flex;gap:8px}
.docs-principal-picker input[type=\"text\"]{flex:1}
.docs-checkbox{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:#334155;margin-top:8px}
.docs-upload-version-panel,.docs-status-panel{max-width:620px}

.docs-v2{--docs-bg:#f0f3fa;--docs-card:#f8f9fd;--docs-border:#d8deeb;--docs-panel:#ffffff;--docs-blue:#24488f;--docs-blue-soft:#eef3ff;--docs-gold:#ddb231}
.docs-v2 .dashboard{background:linear-gradient(180deg,#f8f9fd 0%,#eef2f9 100%)}
.docs-v2 .docs-v1-title-row{margin-bottom:14px}
.docs-v2 .docs-v2-page-title{display:flex;align-items:center;gap:14px;margin:0;color:#1e2c4d;font-size:26px;font-weight:700}
.docs-v2 .docs-page-title-icon{width:38px;height:38px;border-radius:10px;background:#2f5fb8;color:#fff;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 10px 18px rgba(22,52,118,.22)}
.docs-v2 .docs-page-title-icon svg{width:28px;height:28px}

.docs-v2 .docs-v1-card{background:var(--docs-card);border:1px solid var(--docs-border);border-radius:18px;box-shadow:0 18px 36px rgba(20,32,60,.08)}
.docs-v2 .docs-v2-topbar{display:flex;align-items:center;gap:12px;padding:16px 16px 12px;border-bottom:1px solid var(--docs-border)}
.docs-v2 .docs-btn{height:46px;border-radius:12px;font-size:15px;font-weight:700}
.docs-v2 .docs-btn-sm{height:34px;font-size:13px;padding:0 12px}
.docs-v2 .docs-v2-topbar .docs-btn{height:42px;font-size:13px}
.docs-v2 .docs-btn-blue{background:#2f5298;border-color:#2f5298;color:#fff}
.docs-v2 .docs-btn-gold{background:var(--docs-gold);border-color:var(--docs-gold);color:#fff}
.docs-v2 .docs-btn-ghost{background:#f1f4fb;border-color:#d6deee;color:#243250}
.docs-v2 .docs-btn-iconed{display:inline-flex;align-items:center;gap:10px}
.docs-v2 .docs-btn-icon{width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center}
.docs-v2 .docs-btn-icon svg{width:20px;height:20px;display:block}
.docs-v2 .docs-inline-icon{width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 16px}
.docs-v2 .docs-inline-icon svg{width:100%;height:100%;display:block}
.docs-v2 .docs-inline-icon.menu{width:14px;height:14px}
.docs-v2 .docs-btn-icon-only{width:38px;min-width:38px;padding:0}

.docs-v2 .docs-category-tabs-shell{flex:1;min-width:0;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:8px;background:linear-gradient(180deg,#f8fafe 0%,#edf2fb 100%);border:1px solid #c9d2e4;border-radius:12px;padding:6px;box-shadow:inset 0 1px 0 rgba(255,255,255,.9)}
.docs-v2 .docs-tab-nav{width:34px;height:34px;border:1px solid #c4cedf;border-radius:9px;background:#fff;color:#2f4675;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}
.docs-v2 .docs-tab-nav svg{width:18px;height:18px}
.docs-v2 .docs-tab-nav:disabled{opacity:.45;cursor:not-allowed}
.docs-v2 .docs-tab-nav.is-hidden{visibility:hidden;pointer-events:none}
.docs-v2 .docs-category-tabs{min-width:0;overflow-x:auto;overflow-y:hidden;display:flex;align-items:center;gap:0;scroll-behavior:smooth;scrollbar-width:none}
.docs-v2 .docs-category-tabs::-webkit-scrollbar{display:none}
.docs-v2 .docs-category-tab{height:42px;padding:0 14px;border:1px solid #c4cee1;border-radius:0;background:linear-gradient(180deg,#ffffff 0%,#edf2fb 100%);color:#1f2f52;font-size:14px;font-weight:700;display:inline-flex;align-items:center;gap:8px;white-space:nowrap;cursor:pointer;box-shadow:inset 0 1px 0 rgba(255,255,255,.9)}
.docs-v2 .docs-category-tab + .docs-category-tab{margin-left:-1px}
.docs-v2 .docs-category-tab:first-child{border-radius:9px 0 0 9px}
.docs-v2 .docs-category-tab:last-child{border-radius:0 9px 9px 0}
.docs-v2 .docs-category-tab:hover{background:linear-gradient(180deg,#f9fbff 0%,#e6eefc 100%)}
.docs-v2 .docs-category-tab.active{background:linear-gradient(180deg,#f1f6ff 0%,#dee9ff 100%);border-color:#8ea8dd;color:#20457f;position:relative;z-index:1;box-shadow:0 2px 8px rgba(44,78,142,.16), inset 0 1px 0 rgba(255,255,255,.95)}
.docs-v2 .docs-category-tab-icon{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center}
.docs-v2 .docs-category-tab-icon svg{width:100%;height:100%}

.docs-v2 .docs-v2-filters{display:grid;grid-template-columns:minmax(0,1.35fr) repeat(3,minmax(0,1fr));gap:12px;padding:14px 16px 18px;background:transparent;border-bottom:1px solid var(--docs-border)}
.docs-v2 .docs-v2-filters input,.docs-v2 .docs-v2-filters select{height:42px;border:1px solid #ced7ea;border-radius:12px;font-size:14px;padding:0 14px;background:#fff;color:#1f2d4d}
.docs-v2 .docs-v2-filters .docs-btn{height:42px;font-size:13px}
.docs-v2 #docs-filter-keyword{grid-column:1 / span 1}
.docs-v2 #docs-filter-scope{grid-column:2 / span 1}
.docs-v2 #docs-filter-status{grid-column:3 / span 1}
.docs-v2 #docs-filter-sub-category{grid-column:4 / span 1}
.docs-v2 #docs-filter-deep-keyword{grid-column:1 / span 2}
.docs-v2 #docs-filter-deep-search{grid-column:3 / span 1}
.docs-v2 #docs-filter-reset{grid-column:4 / span 1;justify-self:start}
.docs-v2 #docs-filter-category{display:none}

.docs-v2 .docs-v2-section-head{padding:16px;border-bottom:1px solid var(--docs-border);background:#fff}
.docs-v2 .docs-v2-section-title{margin:0;color:#202f4d;font-size:16px;font-weight:700}

.docs-v2 .docs-v1-table{min-width:1120px}
.docs-v2 .docs-v1-table th,.docs-v2 .docs-v1-table td{padding:14px 14px;font-size:13px}
.docs-v2 .docs-v1-table th{background:#f5f6fb;color:#23314f;font-size:13px;font-weight:700}
.docs-v2 .docs-sort-btn{width:100%;border:none;background:none;color:inherit;font:inherit;font-weight:inherit;padding:0;display:flex;align-items:center;justify-content:flex-start;gap:8px;cursor:pointer}
.docs-v2 .docs-sort-btn .docs-sort-indicator::before{content:'↕';font-size:11px;color:#8a95ad}
.docs-v2 .docs-sort-btn.is-active[data-sort-dir="ASC"] .docs-sort-indicator::before{content:'▲';color:#2f5298}
.docs-v2 .docs-sort-btn.is-active[data-sort-dir="DESC"] .docs-sort-indicator::before{content:'▼';color:#2f5298}
.docs-v2 .docs-sort-btn:focus-visible{outline:2px solid #8ea8dd;outline-offset:2px;border-radius:6px}
.docs-v2 .docs-link{font-size:13px}
.docs-v2 .analyst-deep-match{margin-top:6px;padding:7px 8px;border:1px solid #dde4f2;border-radius:8px;background:#f8faff}
.docs-v2 .analyst-deep-match-pos{font-size:11px;color:#536180;line-height:1.3}
.docs-v2 .analyst-deep-match-snippet{margin-top:3px;font-size:12px;color:#25304a;line-height:1.4}
.docs-v2 .analyst-deep-match-snippet mark{background:#ffef9f;color:#1f2a44;padding:0 2px;border-radius:2px}
.docs-v2 .docs-action-group{gap:10px}
.docs-v2 .docs-action-menu{top:44px}
.docs-v2 .docs-action-menu-item{display:flex;align-items:center;gap:8px}

.docs-v2 .status-pill{padding:8px 16px;font-size:13px}

.docs-v2 .app-pagination{padding:16px;border-top:1px solid var(--docs-border)}
.docs-v2 .app-pagination-left,.docs-v2 .app-pagination-info{font-size:13px}
.docs-v2 .app-page-size{height:46px;border-radius:10px;font-size:14px}
.docs-v2 .app-page-btn{height:44px;min-width:44px;border:1px solid #c6cfde;border-radius:9px;background:#fff;color:#233252}
.docs-v2 .app-page-btn svg{width:18px;height:18px;display:block}
.docs-v2 .app-page-input{height:44px;min-width:72px;border-radius:9px;border:1px solid #c6cfde}

@media (max-width: 1400px){
  .docs-v2 .docs-v2-page-title{font-size:23px}
  .docs-v2 .docs-btn{height:42px;font-size:14px}
  .docs-v2 .docs-v2-topbar .docs-btn{height:40px;font-size:13px}
  .docs-v2 .docs-v2-filters input,.docs-v2 .docs-v2-filters select{height:40px;font-size:13px}
  .docs-v2 .docs-v2-filters .docs-btn{height:40px;font-size:13px}
  .docs-v2 .docs-v1-table th,.docs-v2 .docs-v1-table td{font-size:14px;padding:11px 10px}
  .docs-v2 .docs-v1-table th{font-size:13px}
  .docs-v2 .docs-link{font-size:13px}
  .docs-v2 .status-pill{font-size:13px;padding:7px 13px}
  .docs-v2 .app-pagination-left,.docs-v2 .app-pagination-info{font-size:13px}
  .docs-v2 .app-page-size{font-size:14px}
  .docs-v2 .docs-v2-section-title{font-size:16px}
}

@media (max-width: 1024px){
  .docs-v2 .docs-v2-topbar{flex-direction:column;align-items:stretch}
  .docs-v2 .docs-v2-filters{grid-template-columns:1fr 1fr}
  .docs-v2 #docs-filter-keyword{grid-column:1 / span 2}
  .docs-v2 #docs-filter-scope,.docs-v2 #docs-filter-status,.docs-v2 #docs-filter-sub-category,.docs-v2 #docs-filter-deep-keyword,.docs-v2 #docs-filter-deep-search,.docs-v2 #docs-filter-reset{grid-column:auto}
}

@media (max-width: 640px){
  .docs-v2 .docs-v2-page-title{font-size:20px;gap:10px}
  .docs-v2 .docs-page-title-icon{width:42px;height:42px}
  .docs-v2 .docs-v2-filters{grid-template-columns:1fr}
  .docs-v2 #docs-filter-keyword,.docs-v2 #docs-filter-scope,.docs-v2 #docs-filter-status,.docs-v2 #docs-filter-sub-category,.docs-v2 #docs-filter-deep-keyword,.docs-v2 #docs-filter-deep-search,.docs-v2 #docs-filter-reset{grid-column:1 / span 1}
}

/* Customer Batch Processor */
.batch-processor-page{gap:12px}
.batch-processor-card{border-radius:18px}
.batch-tabs{display:flex;align-items:center;gap:0;padding:14px 16px 0;border-bottom:1px solid #d8deeb;background:linear-gradient(180deg,#f8f9fd 0%,#f1f4fb 100%)}
.batch-tab-btn{height:42px;padding:0 16px;border:1px solid #c4cee1;border-radius:0;background:linear-gradient(180deg,#ffffff 0%,#edf2fb 100%);color:#1f2f52;font-size:14px;font-weight:700;display:inline-flex;align-items:center;gap:8px;white-space:nowrap;cursor:pointer;line-height:1;box-shadow:inset 0 1px 0 rgba(255,255,255,.9)}
.batch-tab-btn + .batch-tab-btn{margin-left:-1px}
.batch-tab-btn:first-child{border-radius:10px 0 0 0}
.batch-tab-btn:last-child{border-radius:0 10px 0 0}
.batch-tab-btn:hover{background:linear-gradient(180deg,#f9fbff 0%,#e6eefc 100%)}
.batch-tab-btn.active{background:linear-gradient(180deg,#f1f6ff 0%,#dee9ff 100%);border-color:#8ea8dd;color:#20457f;position:relative;z-index:1;box-shadow:0 2px 8px rgba(44,78,142,.16),inset 0 1px 0 rgba(255,255,255,.95)}
.batch-tab-icon{width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 16px}
.batch-tab-icon svg{width:100%;height:100%;display:block}
.batch-tab-content{display:none;padding:18px 16px;background:#fff}
.batch-tab-content.active{display:block}
.batch-tab-title{margin:0;font-size:17px;color:#1f2a44;font-weight:700}
.batch-tab-note{margin:8px 0 0;font-size:13px;color:#5b6478}
.batch-actions{margin-top:14px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.batch-file-input{height:42px;min-width:300px;max-width:100%;padding:8px 10px;border:1px solid #ced7ea;border-radius:12px;background:#fff;color:#1f2d4d;font-size:13px}

.batch-download-filters{margin-top:16px;display:grid;grid-template-columns:repeat(3,minmax(170px,1fr)) auto;gap:10px;align-items:center}
.batch-download-filters select{height:42px;border:1px solid #ced7ea;border-radius:10px;background:#f7f9fd;color:#1f2d4d;padding:0 12px;font-size:14px}
.batch-download-filters .docs-btn{height:42px}

.batch-download-table-wrap{margin-top:12px;border:1px solid #dbe3f0;border-radius:12px;overflow:auto;background:#fff;min-height:336px;max-height:336px}
.batch-download-table{width:100%;border-collapse:collapse;min-width:900px}
.batch-download-table th,.batch-download-table td{padding:12px;border-bottom:1px solid #e7edf8;text-align:left;color:#27324d;font-size:14px;vertical-align:middle}
.batch-download-table th{background:#f5f7fc;color:#2b3857;font-size:15px;font-weight:700}
.batch-download-table thead th{position:sticky;top:0;z-index:1}
.batch-download-table tbody tr:hover td{background:#fafcff}
.batch-download-table .batch-col-check{width:48px;text-align:center}

.batch-download-check{width:16px;height:16px;cursor:pointer}
.batch-version-pill{display:inline-flex;align-items:center;min-height:26px;padding:3px 10px;border-radius:999px;background:#edf3ff;border:1px solid #d5e1fb;color:#1f3f82;font-size:13px;font-weight:700}
.batch-status-pill{display:inline-flex;align-items:center;min-height:26px;padding:3px 10px;border-radius:999px;background:#eef9f2;border:1px solid #d4eddc;color:#23724c;font-size:13px;font-weight:700}
.batch-status-pill.is-muted{background:#f2f4f8;border-color:#e2e8f0;color:#60708f}
.batch-updated-at{white-space:nowrap}

.batch-download-footer{padding:16px 2px 2px;display:flex;justify-content:space-between;align-items:center;gap:12px}
.batch-download-selection-info{font-size:13px;color:#4a5877}
.batch-download-footer-actions{display:flex;align-items:center;gap:10px}

.batch-download-path-row{display:flex;align-items:center;gap:10px}
.batch-download-path-row input{flex:1 1 auto;height:38px;border:1px solid #cfd8ea;border-radius:10px;background:#f8faff;padding:0 10px;font-size:13px;color:#1f2d4d}
.batch-download-path-row .docs-btn{height:38px;flex:0 0 auto}
.batch-confirm-field small{display:block;color:#5f6d88;font-size:12px;line-height:1.35}

.batch-upload-dropzone{margin-top:14px;border:2px dashed #c9d7f2;border-radius:14px;background:linear-gradient(180deg,#fafcff 0%,#f3f6fd 100%);min-height:220px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 20px;text-align:center;transition:border-color .15s ease,background-color .15s ease,box-shadow .15s ease}
.batch-upload-dropzone:hover{border-color:#98afd9}
.batch-upload-dropzone:focus-visible{outline:none;border-color:#8ea8dd;box-shadow:0 0 0 2px rgba(47,99,221,.16)}
.batch-upload-dropzone.is-dragover{border-color:#6f8fce;background:linear-gradient(180deg,#f6f9ff 0%,#e9f0ff 100%);box-shadow:inset 0 0 0 1px rgba(111,143,206,.3)}
.batch-drop-icon{width:64px;height:64px;color:#3767cb;display:inline-flex;align-items:center;justify-content:center}
.batch-drop-icon svg{width:100%;height:100%}
.batch-drop-title{margin:12px 0 10px;font-size:22px;line-height:1.25;color:#1f2a44;font-weight:700}
.batch-browse-btn{height:46px;min-width:190px;font-size:18px;border-radius:12px}
.batch-drop-tip{margin:14px 0 0;color:#566489;font-size:14px}

.batch-upload-toolbar{margin-top:16px;display:flex;align-items:center;gap:10px}
.batch-category-all{height:42px;min-width:230px;border:1px solid #ced7ea;border-radius:10px;background:#f7f9fd;color:#1f2d4d;padding:0 12px;font-size:14px}

.batch-upload-table-wrap{margin-top:12px;border:1px solid #dbe3f0;border-radius:12px;overflow:auto;background:#fff;min-height:332px;max-height:332px}
.batch-upload-table{width:100%;border-collapse:collapse;min-width:780px}
.batch-upload-table th,.batch-upload-table td{padding:12px;border-bottom:1px solid #e7edf8;text-align:left;color:#27324d;font-size:14px;vertical-align:middle}
.batch-upload-table th{background:#f5f7fc;color:#2b3857;font-size:15px;font-weight:700}
.batch-upload-table thead th{position:sticky;top:0;z-index:1}
.batch-upload-table tbody tr:hover td{background:#fafcff}
.batch-upload-table .batch-col-check{width:48px;text-align:center}
.batch-upload-table .batch-col-action{width:70px;text-align:center}

.batch-row-check,.batch-confirm-all{width:16px;height:16px;cursor:pointer}
.batch-file-name-cell{display:flex;align-items:center;gap:10px;min-width:220px}
.batch-file-icon{width:32px;height:32px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;color:#fff;letter-spacing:.02em}
.batch-file-icon.is-image{background:#2f67dc}
.batch-file-icon.is-pdf{background:#d55656}
.batch-file-icon.is-excel{background:#1e9468}
.batch-file-icon.is-doc{background:#306bd0}
.batch-file-icon.is-unknown{background:#7c879c}
.batch-file-name{font-size:15px;font-weight:700;color:#21396f;word-break:break-all}

.batch-row-category{height:40px;min-width:180px;border:1px solid #cfd8ea;border-radius:10px;background:#f6f8fd;color:#1f2d4d;padding:0 10px;font-size:14px}
.batch-row-size{font-size:15px;color:#2f3a58;font-weight:600;white-space:nowrap}
.batch-row-remove{width:32px;height:32px;border:none;border-radius:8px;background:transparent;color:#d26666;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}
.batch-row-remove:hover{background:#fff0f0}
.batch-row-remove svg{width:20px;height:20px}
.batch-upload-empty-row td{text-align:center;color:#6c7896;padding:20px 12px}

.batch-upload-footer{padding:16px 2px 2px;display:flex;justify-content:flex-end;gap:10px;align-items:center}

.batch-confirm-modal-panel{max-width:760px;width:92%}
.batch-confirm-modal-content{display:flex;flex-direction:column;gap:12px}
.batch-confirm-field{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#475569}
.batch-confirm-field span{font-weight:700;color:#334155}
.batch-confirm-field select{height:38px;border:1px solid #cfd8ea;border-radius:10px;background:#fff;padding:0 10px;font-size:14px;color:#1f2d4d}
.batch-confirm-files{border:1px solid #dfe7f4;border-radius:10px;background:#fbfcff;padding:10px}
.batch-confirm-files-title{font-size:12px;color:#5b6478;font-weight:700;margin-bottom:8px}
.batch-confirm-file-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 18px;max-height:118px;min-height:118px;overflow:auto}
.batch-confirm-file-item{font-size:12px;color:#334155;line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.batch-progress-window{position:fixed;right:18px;bottom:18px;width:370px;background:#fff;border:1px solid #cfd8ea;border-radius:12px;box-shadow:0 18px 40px rgba(15,23,42,.2);z-index:2400}
.batch-progress-window.is-minimized .batch-progress-body{display:none}
.batch-progress-header{height:40px;padding:0 10px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #e6ebf5;background:linear-gradient(180deg,#f8fbff,#edf3ff);font-size:13px;font-weight:700;color:#1f2a44}
.batch-progress-controls{display:flex;align-items:center;gap:6px}
.batch-progress-ctrl{width:24px;height:24px;border:1px solid #d3dcec;border-radius:6px;background:#fff;color:#334155;cursor:pointer;line-height:1}
.batch-progress-ctrl:hover{background:#f4f7ff}
.batch-progress-body{padding:10px}
.batch-progress-bar-track{height:10px;border-radius:999px;background:#e7edf8;overflow:hidden}
.batch-progress-bar-fill{height:100%;width:0;background:linear-gradient(90deg,#d9a41f,#f0bd41);transition:width .25s ease}
.batch-progress-text{margin-top:8px;font-size:12px;color:#334155;font-weight:700}
.batch-progress-summary{margin-top:8px;font-size:12px;color:#334155}
.batch-progress-failures{margin-top:8px;max-height:120px;overflow:auto;border-top:1px solid #edf2fa;padding-top:8px;font-size:12px;color:#b42318}
.batch-progress-failure-item{margin-bottom:4px;line-height:1.35}
.batch-progress-failure-line{display:flex;align-items:center;gap:8px;justify-content:space-between}
.batch-progress-failure-msg{flex:1;min-width:0;white-space:normal;word-break:break-word}
.batch-progress-retry{position:relative;width:26px;height:26px;border:1px solid #d5deef;border-radius:8px;background:#fff;color:#1f3f82;cursor:pointer;padding:0;display:inline-flex;align-items:center;justify-content:center;line-height:1}
.batch-progress-retry svg{width:16px;height:16px;display:block}
.batch-progress-retry:hover:not(:disabled){background:#f1f6ff;border-color:#9fb3dc}
.batch-progress-retry:disabled{opacity:.55;cursor:not-allowed}
.batch-progress-retry[data-tooltip]:hover::after{
  content:attr(data-tooltip);
  position:absolute;
  right:calc(100% + 8px);
  top:50%;
  transform:translateY(-50%);
  background:#111827;
  color:#fff;
  font-size:11px;
  font-weight:600;
  line-height:1;
  padding:5px 7px;
  border-radius:6px;
  white-space:nowrap;
  pointer-events:none;
  z-index:20;
}

@media (max-width: 960px){
  .batch-tabs{padding:12px 12px 0}
  .batch-tab-btn{flex:1 1 0;justify-content:center}
  .batch-tab-content{padding:14px 12px}
  .batch-download-filters{grid-template-columns:1fr 1fr}
  .batch-download-filters .docs-btn{grid-column:1 / span 2}
  .batch-download-footer{flex-direction:column;align-items:stretch}
  .batch-download-footer-actions{width:100%}
  .batch-download-footer-actions .docs-btn{flex:1 1 0}
  .batch-download-path-row{flex-direction:column;align-items:stretch}
  .batch-file-input{min-width:220px;width:100%}
  .batch-drop-title{font-size:18px}
  .batch-browse-btn{height:42px;min-width:170px;font-size:16px}
  .batch-drop-tip{font-size:13px}
  .batch-category-all{min-width:200px}
  .batch-upload-footer{justify-content:stretch}
  .batch-upload-footer .docs-btn{flex:1 1 0}
  .batch-confirm-file-grid{grid-template-columns:1fr}
  .batch-progress-window{left:12px;right:12px;width:auto}
}

.docs-detail-tabs{display:flex;gap:8px;padding:10px 12px;border-bottom:1px solid var(--docs-border);background:#f7f9ff}
.docs-detail-tab{height:34px;padding:0 14px;border-radius:8px;border:1px solid #d6dff0;background:#eef2fb;color:#24314f;font-size:14px;font-weight:700;cursor:pointer}
.docs-detail-tab.active{background:#1f3f82;border-color:#1f3f82;color:#fff}
.docs-detail-panel{display:none;padding:14px}
.docs-detail-panel.active{display:block}

.docs-overview-grid{display:grid;grid-template-columns:repeat(4,minmax(170px,1fr));gap:10px}
.docs-overview-cell{background:#fff;border:1px solid #e2e9f4;border-radius:10px;padding:10px}
.docs-overview-cell label{display:block;font-size:12px;color:#6b7280;margin-bottom:4px}
.docs-overview-cell strong{font-size:15px;color:#1f2a44;font-weight:700}
.docs-overview-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:12px;flex-wrap:wrap}
.docs-panel-toolbar{display:flex;justify-content:flex-end;padding-bottom:10px}
.docs-audit-filters{grid-template-columns:repeat(5,minmax(140px,1fr)) auto;padding:0 0 12px;background:transparent;border-bottom:none}

@media (max-width: 1400px){
  .docs-v1-filters{grid-template-columns:minmax(220px,2fr) repeat(4,minmax(120px,1fr));}
}
@media (max-width: 1100px){
  .docs-v1-title-row h2{font-size:16px}
  .docs-v1-filters{grid-template-columns:1fr 1fr;}
  .docs-form-grid{grid-template-columns:1fr}
  .docs-overview-grid{grid-template-columns:repeat(2,minmax(160px,1fr))}
}
@media (max-width: 720px){
  .docs-overview-grid{grid-template-columns:1fr}
  .docs-overview-actions{justify-content:flex-start}
}

/* Unified pagination + 5-row viewport policy */
:root{
  --app-pagination-row-height: 52px;
  --app-pagination-max-visible-rows: 5;
}

.um-table-wrap,
.docs-table-wrap,
.docs-v1-table-wrap{
  max-height: calc((var(--app-pagination-row-height) * (var(--app-pagination-max-visible-rows) + 1)) + 4px);
  overflow: auto;
}

.um-table thead th,
.docs-table thead th,
.docs-v1-table thead th{
  position: sticky;
  top: 0;
  z-index: 1;
}

.app-sortable-th{
  cursor: pointer;
  user-select: none;
}

.app-sortable-th::after{
  content: '↕';
  margin-left: 6px;
  font-size: 11px;
  color: #8a95ad;
}

.app-sortable-th[data-sort-dir="asc"]::after{
  content: '▲';
  color: #2f5298;
}

.app-sortable-th[data-sort-dir="desc"]::after{
  content: '▼';
  color: #2f5298;
}

.app-pagination,
.resource-pagination-row,
.docs-v1-pagination,
.docs-pagination,
.um-pagination{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
  padding: 14px 16px;
  border-top: 1px solid #e6ebf5;
  background: #fff;
}

.app-pagination-left{
  display: flex;
  align-items: center;
  gap: 10px;
  color: #5b6478;
  font-size: 13px;
  font-weight: 500;
}

.app-pagination-left label{
  white-space: nowrap;
}

.app-page-size{
  height: 38px;
  min-width: 88px;
  border: 1px solid #b8c2d8;
  border-radius: 6px;
  padding: 0 10px;
  background: #fff;
  color: #24314f;
  font-size: 14px;
}

.app-pagination-info{
  white-space: nowrap;
  color: #606a7f;
  font-size: 13px;
}

.app-pagination-right{
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 8px;
}

.app-page-btn{
  height: 36px;
  min-width: 42px;
  padding: 0 10px;
  border: 1px solid transparent;
  border-radius: 6px;
  background: transparent;
  color: #334155;
  font-weight: 600;
  font-size: 14px;
  cursor: pointer;
}

.app-page-btn.app-page-prev,
.app-page-btn.app-page-next,
.app-page-btn.app-page-prev-label,
.app-page-btn.app-page-next-label{
  min-width: 36px;
  font-size: 14px;
  line-height: 1;
  color: #334155;
  font-weight: 600;
  padding: 0 6px;
}

.app-page-btn:hover:not(:disabled){
  color: #1d4f91;
  background: #f5f8ff;
}

.app-page-btn:disabled{
  opacity: 0.55;
  color: #94a3b8;
  cursor: not-allowed;
}

.app-page-input{
  width: 56px;
  height: 36px;
  border: 1px solid #8b95a8;
  border-radius: 4px;
  padding: 0 8px;
  text-align: center;
  font-size: 14px;
  font-weight: 600;
  line-height: 1;
  color: #334155;
}

.app-page-total{
  color: #606a7f;
  font-size: 14px;
  white-space: nowrap;
}

/* Audit page (tabs placeholder) */
.audit-page .dashboard{background:#f4f6fb}
.audit-dashboard{gap:12px}
.audit-shell-card{background:#fff;border:1px solid #e2e8f3;border-radius:14px;overflow:hidden;box-shadow:0 10px 26px rgba(16,24,40,.08)}
.audit-content{padding:18px 20px}
.audit-content h3{margin:0 0 10px;font-size:20px;color:#1f2a44;font-weight:700;line-height:1.15}
.audit-content p{margin:0;color:#667085;font-size:10px}
.email-audit-module{display:flex;flex-direction:column;gap:14px}
.email-audit-filters{display:grid;grid-template-columns:repeat(3,minmax(180px,1fr)) auto;gap:10px;align-items:end}
.email-audit-filters label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#475569}
.email-audit-filters input{height:38px;border:1px solid #d8deec;border-radius:8px;padding:0 10px;background:#fff;font-size:14px;color:#1f2a44}
.email-audit-actions{display:flex;justify-content:flex-end}
.email-audit-table-wrap{border:1px solid #e6ebf5;border-radius:10px;overflow:auto}
.email-audit-table th,.email-audit-table td{vertical-align:top}
.email-audit-table td:nth-child(2){max-width:440px;word-break:break-word}
.email-audit-subject-btn{border:none;background:none;padding:0;color:#1d4f91;font:inherit;font-weight:700;cursor:pointer;text-align:left}
.email-audit-subject-btn:hover{color:#153d71;text-decoration:underline}
.email-audit-subject-btn:focus-visible{outline:2px solid #7ea4e3;outline-offset:2px;border-radius:4px}
.email-audit-empty{text-align:center;color:#667085;padding:16px 12px}
.email-audit-pagination{padding:0 0 6px}
.user-audit-module{display:flex;flex-direction:column;gap:14px}
.user-audit-filters{display:grid;grid-template-columns:repeat(4,minmax(160px,1fr)) auto;gap:10px;align-items:end}
.user-audit-filters label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#475569}
.user-audit-filters input,.user-audit-filters select{height:38px;border:1px solid #d8deec;border-radius:8px;padding:0 10px;background:#fff;font-size:14px;color:#1f2a44}
.user-audit-actions{display:flex;justify-content:flex-end}
.user-audit-table-wrap{border:1px solid #e6ebf5;border-radius:10px;overflow:auto}
.user-audit-table th,.user-audit-table td{vertical-align:top}
.user-audit-empty{text-align:center;color:#667085;padding:16px 12px}
.user-audit-pagination{padding:0 0 6px}
.audit-doc-module{display:flex;flex-direction:column;gap:14px}
.audit-doc-filters{display:grid;grid-template-columns:repeat(3,minmax(180px,1fr)) auto;gap:10px;align-items:end}
.audit-doc-filters label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#475569}
.audit-doc-filters input{height:38px;border:1px solid #d8deec;border-radius:8px;padding:0 10px;background:#fff;font-size:14px;color:#1f2a44}
.audit-doc-actions{display:flex;justify-content:flex-end}
.audit-doc-table-wrap{border:1px solid #e6ebf5;border-radius:10px;overflow:auto}
.audit-doc-table th,.audit-doc-table td{vertical-align:top}
.audit-doc-table .audit-col-action{max-width:520px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.audit-doc-empty{text-align:center;color:#667085;padding:16px 12px}
.audit-doc-pagination{padding:0 0 6px}
.event-audit-module{display:flex;flex-direction:column;gap:14px}
.event-audit-filters{display:grid;grid-template-columns:repeat(3,minmax(180px,1fr)) auto;gap:10px;align-items:end}
.event-audit-filters label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#475569}
.event-audit-filters input{height:38px;border:1px solid #d8deec;border-radius:8px;padding:0 10px;background:#fff;font-size:14px;color:#1f2a44}
.event-audit-actions{display:flex;justify-content:flex-end}
.event-audit-table-wrap{border:1px solid #e6ebf5;border-radius:10px;overflow:auto}
.event-audit-table th,.event-audit-table td{vertical-align:top}
.event-audit-table td:nth-child(4){max-width:320px;word-break:break-word}
.event-audit-question{max-width:640px;white-space:pre-wrap;word-break:break-word}
.event-audit-empty{text-align:center;color:#667085;padding:16px 12px}
.event-audit-pagination{padding:0 0 6px}
.audit-detail-content{display:flex;flex-direction:column;gap:8px}
.audit-detail-content p{margin:0;font-size:13px;color:#334155}
.audit-detail-content pre{margin:0;border:1px solid #e5eaf4;border-radius:8px;background:#fafcff;padding:10px;font-size:12px;line-height:1.45;color:#334155;white-space:pre-wrap;word-break:break-word;max-height:180px;overflow:auto}

@media (max-width: 960px){
  .email-audit-filters{grid-template-columns:1fr}
  .email-audit-actions{justify-content:flex-start}
  .user-audit-filters{grid-template-columns:1fr}
  .user-audit-actions{justify-content:flex-start}
  .audit-doc-filters{grid-template-columns:1fr}
  .audit-doc-actions{justify-content:flex-start}
  .event-audit-filters{grid-template-columns:1fr}
  .event-audit-actions{justify-content:flex-start}
}

/* Clients overview page */
.clients-v1 .dashboard{background:#f4f6fb}
.clients-v1-page{gap:12px}
.clients-v1-title-row{display:flex;align-items:center;justify-content:space-between}
.clients-v1-title-row h2{margin:0;font-size:20px;font-weight:800;color:#1f2a44}
.clients-v1-card{background:#fff;border:1px solid #e2e8f3;border-radius:14px;overflow:hidden;box-shadow:0 10px 26px rgba(16,24,40,.08)}
.clients-v1-profile-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:16px;border-bottom:1px solid #e8edf7}
.clients-v1-profile-left{display:flex;gap:14px;align-items:flex-start;min-width:0}
.clients-v1-avatar-wrap{position:relative}
.clients-v1-avatar{width:96px;height:96px;border-radius:50%;object-fit:cover;border:3px solid #fff;box-shadow:0 8px 20px rgba(15,23,42,.2)}
.clients-v1-header-main{min-width:0}
.clients-v1-title-line{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.clients-v1-title-line h3{margin:0;font-size:52px;line-height:1;font-weight:700;color:#1f2a44}
.clients-v1-client-select{display:flex;align-items:center;gap:8px}
.clients-v1-client-select label{font-size:13px;color:#5b6478;font-weight:600}
.clients-v1-client-select select{height:34px;border:1px solid #d5deed;border-radius:8px;padding:0 10px;font-size:13px;color:#23314f;background:#fff;min-width:240px}
.clients-v1-code{font-size:18px;color:#667085;margin-top:6px}
.clients-v1-meta{display:flex;align-items:center;gap:10px;margin-top:10px;color:#2a3550;font-weight:600}
.clients-v1-contact-line{display:flex;align-items:center;gap:8px;color:#4b5568;margin-top:6px;font-size:16px}
.clients-v1-profile-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.clients-v1-kpi-row{display:grid;grid-template-columns:repeat(3,minmax(180px,1fr));gap:12px;padding:0 16px 16px}
.clients-kpi-card{border:1px solid #e0e6f3;border-radius:12px;background:#fff;padding:14px}
.clients-kpi-value{font-size:26px;font-weight:800;color:#1f2a44;line-height:1.05}
.clients-kpi-label{margin-top:6px;color:#667085;font-size:16px;font-weight:600}
.clients-v1-tabs{display:flex;gap:2px;border-top:1px solid #e8edf7;border-bottom:1px solid #e8edf7;background:#fff;padding:0 10px}
.clients-tab{height:46px;padding:0 18px;border:none;background:transparent;color:#2c3854;font-size:16px;font-weight:600;cursor:pointer;border-bottom:3px solid transparent}
.clients-tab.active{color:#1f2a44;border-bottom-color:#d8a72c}
.clients-tab-panel{display:none;padding:14px}
.clients-tab-panel.active{display:block}
.clients-overview-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:14px}
.clients-overview-card{border:1px solid #e2e8f3;border-radius:12px;background:#fff;overflow:hidden}
.clients-card-title{font-size:18px;color:#1f2a44;font-weight:700;padding:14px;border-bottom:1px solid #e8edf7}
.clients-info-list{padding:10px 14px}
.clients-info-item{padding:10px 0;border-bottom:1px solid #eef2fa;display:flex;flex-direction:column;gap:6px}
.clients-info-item:last-child{border-bottom:none}
.clients-info-item label{color:#5b6478;font-size:13px;font-weight:600}
.clients-info-item strong{color:#1f2a44;font-size:16px;font-weight:600}
.clients-tag-wrap{display:flex;flex-wrap:wrap;gap:8px;min-height:18px}
.clients-tag-chip{display:inline-flex;align-items:center;height:24px;padding:0 10px;border-radius:999px;background:#eef3ff;color:#2a3b62;font-size:12px;font-weight:600}
.clients-table th,.clients-table td{font-size:12px}
.clients-table-sub{color:#667085;font-size:11px;line-height:1.2;margin-top:3px}
.clients-modal-panel{max-width:720px}
.clients-edit-modal-panel{max-width:860px}
#clients-activity-detail{min-height:90px;resize:vertical;border:1px solid #d5deed;border-radius:8px;padding:8px 10px;font-size:14px;color:#1f2a44}
.clients-form-textarea{min-height:88px;resize:vertical;border:1px solid #d5deed;border-radius:8px;padding:8px 10px;font-size:14px;color:#1f2a44;font-family:inherit}
.clients-checkbox{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:#334155;margin-top:4px}

@media (max-width: 1280px){
  .clients-v1-title-line h3{font-size:28px}
  .clients-kpi-value{font-size:22px}
  .clients-kpi-label{font-size:16px}
  .clients-card-title{font-size:18px}
  .clients-info-item label{font-size:13px}
  .clients-info-item strong{font-size:16px}
  .clients-table th,.clients-table td{font-size:12px}
  .clients-table-sub{font-size:11px}
  .clients-tab{font-size:15px}
}

@media (max-width: 960px){
  .clients-v1-profile-row{flex-direction:column}
  .clients-v1-kpi-row{grid-template-columns:1fr}
  .clients-overview-grid{grid-template-columns:1fr}
  .clients-v1-client-select select{min-width:180px}
}

/* Finance dashboard */
.fin-page{
  --fin-bg:#f3f6fb;
  --fin-card:#ffffff;
  --fin-border:#dbe3f2;
  --fin-text:#1f2c49;
  --fin-muted:#6a7895;
  --fin-blue:#2b74ff;
  --fin-green:#1f9d5b;
  --fin-red:#d0474e;
}

.fin-dashboard{
  background:linear-gradient(180deg,#f7f9ff 0%,#eff3fb 100%);
  padding:20px;
  gap:16px;
}

.fin-search-row{
  background:var(--fin-card);
  border:1px solid var(--fin-border);
  border-radius:16px;
  padding:14px;
  box-shadow:0 12px 26px rgba(15,23,42,.06);
  position:relative;
}

.fin-search-box{
  display:flex;
  align-items:center;
  gap:10px;
  border:1px solid #d1dbef;
  border-radius:12px;
  background:#f9fbff;
  overflow:hidden;
}

.fin-search-icon{
  width:48px;
  min-width:48px;
  text-align:center;
  color:#6e7f9f;
  font-size:18px;
}

.fin-search-box input{
  border:none;
  outline:none;
  background:transparent;
  color:var(--fin-text);
  font-size:16px;
  font-weight:500;
  letter-spacing:.2px;
  height:44px;
  width:100%;
  padding-right:8px;
}

.fin-search-btn{
  border:none;
  background:linear-gradient(135deg,#2f7bff,#1f56cc);
  color:#fff;
  height:44px;
  min-width:96px;
  font-size:13px;
  font-weight:700;
  cursor:pointer;
}

.fin-search-btn:hover{filter:brightness(1.03)}

.fin-search-suggest{
  position:absolute;
  left:14px;
  right:14px;
  top:calc(100% - 4px);
  border:1px solid #ccd8f0;
  border-radius:12px;
  background:#fff;
  box-shadow:0 18px 36px rgba(15,23,42,.14);
  z-index:30;
  overflow:hidden;
}

.fin-suggest-item{
  width:100%;
  border:none;
  border-bottom:1px solid #ecf2ff;
  background:#fff;
  text-align:left;
  cursor:pointer;
  display:grid;
  grid-template-columns:minmax(120px,180px) 1fr auto;
  gap:10px;
  align-items:center;
  padding:10px 12px;
  color:#1f2c49;
}

.fin-suggest-item:last-child{border-bottom:none}
.fin-suggest-item:hover,.fin-suggest-item.active{background:#eef4ff}
.fin-suggest-symbol{font-size:13px;font-weight:700;color:#1f56cc}
.fin-suggest-name{font-size:13px;font-weight:600;color:#1f2c49;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.fin-suggest-meta{font-size:12px;color:#5f7092}
.fin-suggest-empty{padding:11px 12px;font-size:13px;color:#5f7092}

.fin-index-row{
  display:grid;
  grid-template-columns:repeat(5,minmax(160px,1fr));
  gap:12px;
  align-items:start;
}

.fin-index-card{
  background:var(--fin-card);
  border:1px solid var(--fin-border);
  border-radius:14px;
  padding:12px 12px 8px;
  box-shadow:0 10px 24px rgba(15,23,42,.05);
}

.fin-index-title{
  font-size:14px;
  font-weight:700;
  color:var(--fin-text);
  margin-bottom:8px;
}
.fin-index-header{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:8px;
}
.fin-index-header .fin-index-title{
  margin-bottom:0;
}
.fin-index-indicator{
  width:34px;
  height:34px;
  border-radius:10px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:22px;
  font-weight:800;
  line-height:1;
}
.fin-index-indicator.up{
  color:var(--fin-green);
  background:rgba(42,166,99,.14);
}
.fin-index-indicator.down{
  color:var(--fin-red);
  background:rgba(210,75,79,.14);
}
.fin-index-indicator.flat{
  color:var(--fin-muted);
  background:rgba(100,116,139,.16);
}

.fin-index-quote{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:8px;
  font-size:13px;
  color:var(--fin-text);
}

.fin-index-change.up{color:var(--fin-green)}
.fin-index-change.down{color:var(--fin-red)}
.fin-index-change.flat{color:var(--fin-muted)}

.fin-index-graph{margin-top:8px;height:70px}
.fin-sparkline{width:100%;height:70px;display:block}
.fin-index-card.no-trend{padding-bottom:12px}
.fin-index-card.no-trend .fin-index-graph{display:none}

.fin-main-grid{
  display:grid;
  grid-template-columns:minmax(230px,260px) minmax(420px,1fr) minmax(300px,360px);
  gap:12px;
}

.fin-col{display:flex;flex-direction:column;gap:12px;min-width:0}

.fin-card{
  background:var(--fin-card);
  border:1px solid var(--fin-border);
  border-radius:14px;
  box-shadow:0 12px 26px rgba(15,23,42,.06);
  overflow:hidden;
}

.fin-card-head{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:8px;
  padding:12px 14px;
  border-bottom:1px solid #e5ebf7;
  position:relative;
}

.fin-card-head h3{margin:0;color:var(--fin-text);font-size:18px;line-height:1.15}
.fin-card-meta{font-size:13px;color:var(--fin-muted)}

.fin-watchlist-menu-wrap{position:relative;margin-left:auto}
.fin-watchlist-menu-btn{
  border:1px solid #cfd8ea;
  background:#fff;
  color:#334155;
  border-radius:8px;
  min-width:34px;
  height:30px;
  padding:0 8px;
  font-size:16px;
  font-weight:700;
  cursor:pointer;
  line-height:1;
}
.fin-watchlist-menu-btn:hover{background:#f4f7ff}
.fin-watchlist-menu{
  position:absolute;
  right:0;
  top:34px;
  min-width:150px;
  border:1px solid #d7e0f2;
  background:#fff;
  border-radius:10px;
  box-shadow:0 16px 34px rgba(15,23,42,.14);
  z-index:12;
  padding:6px;
  display:flex;
  flex-direction:column;
  gap:4px;
}
.fin-watchlist-menu[hidden]{display:none !important}
.fin-watchlist-menu button{
  border:none;
  background:#fff;
  color:#1f2c49;
  text-align:left;
  border-radius:8px;
  padding:8px 10px;
  font-size:13px;
  cursor:pointer;
}
.fin-watchlist-menu button:hover{background:#edf3ff}

.fin-watchlist{display:flex;flex-direction:column;padding:6px 10px 10px;gap:4px}

.fin-watch-item{
  width:100%;
  border:1px solid transparent;
  background:#fff;
  border-radius:10px;
  display:grid;
  grid-template-columns:1fr auto auto;
  gap:8px;
  align-items:center;
  padding:9px 10px;
  color:var(--fin-text);
  text-align:left;
  cursor:pointer;
}
.fin-watch-item.manage-mode{
  grid-template-columns:1fr auto auto auto;
  cursor:default;
}

.fin-watch-item:hover{background:#f5f8ff;border-color:#d9e4fb}
.fin-watch-item.active{background:#ecf3ff;border-color:#bcd0fb}
.fin-watch-symbol{font-size:15px;font-weight:700;line-height:1}
.fin-watch-price{font-size:15px;font-weight:700;line-height:1}
.fin-watch-change{font-size:14px;font-weight:700;line-height:1}
.fin-watch-change.up{color:var(--fin-green)}
.fin-watch-change.down{color:var(--fin-red)}
.fin-watch-change.flat{color:var(--fin-muted)}
.fin-watch-remove{
  border:1px solid #e6c7cc;
  color:#b42318;
  background:#fff;
  border-radius:8px;
  height:26px;
  min-width:46px;
  padding:0 8px;
  font-size:12px;
  font-weight:700;
  cursor:pointer;
}
.fin-watch-remove:hover{background:#fff6f7}

.fin-hero-card{padding-bottom:10px}
.fin-hero-card .fin-card-head h3{font-size:22px}
.fin-hero-quote{padding:14px 16px 0;font-size:32px;font-weight:800;color:var(--fin-text);line-height:1}
.fin-hero-change{padding:6px 16px 0;font-size:20px;font-weight:700;line-height:1.1}
.fin-hero-change.up{color:var(--fin-green)}
.fin-hero-change.down{color:var(--fin-red)}
.fin-hero-change.flat{color:var(--fin-muted)}

.fin-range-tabs{display:flex;gap:8px;padding:12px 16px 2px;flex-wrap:wrap}
.fin-range-tabs button{
  border:1px solid #d0daf0;
  background:#fff;
  color:#405071;
  border-radius:8px;
  height:34px;
  min-width:56px;
  padding:0 12px;
  font-size:14px;
  font-weight:700;
  cursor:pointer;
}
.fin-range-tabs button.active{background:#edf3ff;color:#1f56cc;border-color:#adc3f5}

.fin-line-chart-wrap{padding:10px 12px 8px}
#finLineChart{display:block;width:100%;height:300px;border:1px solid #e6ecf8;border-radius:10px;background:linear-gradient(180deg,#fbfdff,#f2f7ff)}

.fin-metrics{display:flex;flex-direction:column;padding:8px 14px 12px}
.fin-metric-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 0;border-bottom:1px solid #edf2fb}
.fin-metric-row:last-child{border-bottom:none}
.fin-metric-label{font-size:13px;color:#4b5d82;font-weight:600}
.fin-metric-value{font-size:16px;color:var(--fin-text);font-weight:800}

.fin-movers-grid{display:grid;grid-template-columns:1fr;gap:10px;padding:10px}
.fin-movers-grid section{border:1px solid #e4ebf8;border-radius:10px;background:#fbfdff;overflow:hidden}
.fin-movers-grid h4{margin:0;padding:10px 12px;border-bottom:1px solid #e6edf9;font-size:15px;color:var(--fin-text)}
.fin-mini-list{padding:6px 10px 10px;display:flex;flex-direction:column;gap:4px}
.fin-mini-row{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center;padding:8px 4px;border-bottom:1px solid #eef3fc}
.fin-mini-row:last-child{border-bottom:none}
.fin-mini-symbol{font-size:14px;font-weight:700;color:var(--fin-text)}
.fin-mini-price{font-size:14px;font-weight:700;color:var(--fin-text)}
.fin-mini-change{font-size:13px;font-weight:700;text-align:right}
.fin-mini-change.up{color:var(--fin-green)}
.fin-mini-change.down{color:var(--fin-red)}
.fin-mini-change.flat{color:var(--fin-muted)}

.fin-news-list{display:flex;flex-direction:column;padding:10px;gap:10px}
.fin-news-item{display:grid;grid-template-columns:1fr 110px;gap:10px;border:1px solid #e4ebf8;border-radius:10px;background:#fff;padding:10px}
.fin-news-title{font-size:15px;font-weight:700;color:#1f56cc;text-decoration:none;line-height:1.25}
.fin-news-title:hover{text-decoration:underline}
.fin-news-meta{margin-top:5px;font-size:12px;color:var(--fin-muted)}
.fin-news-thumb{width:110px;height:74px;border-radius:8px;overflow:hidden;background:#eef3fd}
.fin-news-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.fin-news-noimg{width:100%;height:100%;background:linear-gradient(120deg,#dce6fa,#f0f4fd)}

.fin-loading,.fin-empty,.fin-error{padding:14px;font-size:13px;color:#64748b}
.fin-error{color:#b42318}

@media (max-width: 1500px){
  .fin-index-row{grid-template-columns:repeat(3,minmax(160px,1fr))}
}

@media (max-width: 1300px){
  .fin-main-grid{grid-template-columns:minmax(230px,270px) 1fr}
  .fin-right-col{grid-column:1 / -1;display:grid;grid-template-columns:1fr 1fr;align-items:start}
}

@media (max-width: 980px){
  .fin-search-box input{font-size:15px;height:42px}
  .fin-search-btn{height:42px;min-width:88px;font-size:12px}
  .fin-suggest-item{grid-template-columns:1fr;gap:3px}
  .fin-index-row{grid-template-columns:repeat(2,minmax(160px,1fr))}
  .fin-main-grid{grid-template-columns:1fr}
  .fin-right-col{display:flex;grid-template-columns:none}
  .fin-card-head h3{font-size:16px}
  .fin-hero-card .fin-card-head h3{font-size:19px}
  .fin-hero-quote{font-size:28px}
  .fin-hero-change{font-size:18px}
  .fin-watch-symbol,.fin-watch-price{font-size:14px}
  .fin-watch-change{font-size:13px}
  .fin-mini-symbol,.fin-mini-price{font-size:13px}
  .fin-mini-change{font-size:12px}
  .fin-news-title{font-size:14px}
  .fin-news-meta{font-size:12px}
}

/* Products (VC style) */
.products-vc-page{
  --prod-bg:#f1f4fa;
  --prod-card:#ffffff;
  --prod-border:#d9e0ee;
  --prod-text:#1f2a44;
  --prod-muted:#5f6d88;
  --prod-blue:#2f63dd;
  height:auto;
  min-height:100vh;
  overflow:auto;
}
.products-vc-page .internal-layout{
  height:auto;
  min-height:100vh;
  overflow:visible;
  min-width:calc(var(--internal-sidebar-width) + 1240px);
}
.products-vc-page .internal-main{
  height:auto;
  min-height:100vh;
  overflow:visible;
}
.products-vc-page .dashboard.products-dashboard{
  background:linear-gradient(180deg,#f8f9fe 0%, var(--prod-bg) 100%);
  gap:14px;
  width:1240px;
  min-width:1240px;
  max-width:1240px;
  margin:0 auto;
}
.products-vc-page .internal-main > main{
  overflow:auto;
  scrollbar-gutter:stable both-edges;
}
.products-vc-page .products-list-card > .um-table-wrap{
  max-height:none;
}
.products-header-card{
  background:var(--prod-card);
  border:1px solid var(--prod-border);
  border-radius:14px;
  padding:16px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.products-header-main h2{margin:6px 0 0;font-size:30px;line-height:1;color:var(--prod-text)}
.products-breadcrumb{display:flex;align-items:center;gap:8px;color:var(--prod-muted);font-size:13px}
.products-header-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.products-kpi-grid{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:10px;
}
.products-kpi-card{
  background:var(--prod-card);
  border:1px solid var(--prod-border);
  border-radius:12px;
  padding:10px 12px;
}
.products-kpi-card .kpi-value{font-size:20px;font-weight:800;color:#1e2f53;line-height:1.1}
.products-kpi-card .kpi-title{margin-top:6px;font-size:11px;color:var(--prod-muted);font-weight:700;letter-spacing:.02em}
.products-kpi-card .kpi-title::before{
  content:'◦';
  margin-right:6px;
  color:#506ea8;
}
.products-quick-tabs{
  background:var(--prod-card);
  border:1px solid var(--prod-border);
  border-radius:12px;
  padding:0;
  display:flex;
  align-items:stretch;
  gap:0;
  overflow-x:scroll;
  overflow-y:hidden;
  min-height:38px;
  scrollbar-gutter:stable both-edges;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.82),
    inset 0 -1px 0 rgba(190,203,230,.58),
    0 10px 24px rgba(31,42,68,.06);
}
.products-quick-tabs button{
  border:none;
  border-right:1px solid #cfd8ec;
  border-top:1px solid #ebf1fc;
  border-bottom:1px solid #b8c7e7;
  background:linear-gradient(180deg,#ffffff 0%, #eef3fd 48%, #dde7fb 100%);
  color:#233055;
  font-size:12px;
  font-weight:700;
  height:36px;
  padding:0 10px;
  cursor:pointer;
  white-space:nowrap;
  width:auto;
  flex:0 0 148px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  text-shadow:0 1px 0 rgba(255,255,255,.7);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9), inset 0 -1px 0 rgba(160,178,216,.35);
  transition:transform .16s ease, box-shadow .16s ease, background .16s ease, color .16s ease;
}
.products-quick-tabs button::before{
  display:inline-block;
  margin-right:6px;
  font-size:11px;
  opacity:.82;
  line-height:1;
}
.products-quick-tabs button[data-code="ALL"]::before{content:'◉';}
.products-quick-tabs button[data-code="FUND"]::before{content:'◌';}
.products-quick-tabs button[data-code="SPV"]::before{content:'◈';}
.products-quick-tabs button[data-code="SYNDICATE"]::before{content:'◎';}
.products-quick-tabs button[data-code="PROGRAM"]::before{content:'◇';}
.products-quick-tabs button[data-code="MANDATE"]::before{content:'◍';}
.products-quick-tabs button:first-child{
  border-top-left-radius:12px;
  border-bottom-left-radius:12px;
}
.products-quick-tabs button:last-child{
  border-right:none;
  border-top-right-radius:12px;
  border-bottom-right-radius:12px;
}
.products-quick-tabs button:hover{
  background:linear-gradient(180deg,#ffffff 0%, #f4f8ff 45%, #e7efff 100%);
  transform:translateY(-1px);
}
.products-quick-tabs button.active{
  background:linear-gradient(180deg,#fefefe 0%, #eef4ff 42%, #d5e3ff 100%);
  color:#1d4eaf;
  border-bottom-color:#8fa9de;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 8px 18px rgba(47,99,221,.18);
  position:relative;
  z-index:1;
}
.products-main-grid{
  display:grid;
  grid-template-columns:minmax(0,72%) minmax(0,28%);
  gap:12px;
  align-items:stretch;
}
.products-card{
  background:var(--prod-card);
  border:1px solid var(--prod-border);
  border-radius:12px;
  overflow:hidden;
}
.products-list-card{
  display:flex;
  flex-direction:column;
  min-height:500px;
  height:500px;
}
.products-filter-row{
  display:grid;
  grid-template-columns:minmax(220px,1.8fr) repeat(4,minmax(0,1fr)) auto;
  gap:8px;
  padding:12px;
  background:#f7f9ff;
  border-bottom:1px solid #e3e9f5;
}
.products-filter-row input,.products-filter-row select{
  height:40px;
  border:1px solid #cfd7ea;
  border-radius:10px;
  padding:0 12px;
  color:#1f2a44;
  background:#fff;
  font-size:14px;
}
.products-sort{
  border:none;
  background:transparent;
  color:#33415f;
  font-weight:800;
  font-size:11px;
  cursor:pointer;
  padding:0;
  line-height:1.1;
}
.products-sort.active{color:#1f56cc}
.products-sort[data-dir="asc"]::after{content:' ▲';font-size:10px}
.products-sort[data-dir="desc"]::after{content:' ▼';font-size:10px}
.products-list-card > .um-table-wrap{
  flex:1;
  min-height:0;
  overflow:auto;
  scrollbar-gutter:stable both-edges;
}
.products-list-card > .um-table-wrap .um-table{
  min-width:980px;
}
.products-pagination{padding:10px 12px}
.products-summary-card{
  display:flex;
  flex-direction:column;
  min-height:500px;
  height:500px;
}
.products-card-head{padding:12px 14px;border-bottom:1px solid #e5ebf7;background:#f8faff}
.products-card-head h3{margin:0;font-size:20px;color:#1f2a44}
.products-summary-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.products-summary-head-main{display:flex;align-items:center;min-height:36px}
.products-summary-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:6px;
  flex-wrap:wrap;
}
.products-action-icon-btn{
  height:28px;
  border:1px solid #c6d4ef;
  border-radius:8px;
  background:linear-gradient(180deg,#ffffff 0%, #edf3ff 100%);
  color:#233c6d;
  font-size:11px;
  font-weight:700;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:4px;
  padding:0 6px;
  cursor:pointer;
  white-space:nowrap;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.95);
  transition:background .15s ease, transform .12s ease, box-shadow .15s ease;
}
.products-action-icon-btn:hover:not(:disabled){
  background:linear-gradient(180deg,#ffffff 0%, #e4edff 100%);
  box-shadow:0 6px 14px rgba(47,99,221,.16);
  transform:translateY(-1px);
}
.products-action-icon-btn:active:not(:disabled){
  transform:translateY(0);
}
.products-action-icon-btn:disabled{
  opacity:.6;
  cursor:not-allowed;
}
.products-action-icon{
  width:14px;
  height:14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.products-action-icon svg{
  width:14px;
  height:14px;
  display:block;
  fill:currentColor;
}
.products-summary-body{
  padding:12px 14px;
  flex:1;
  min-height:0;
  overflow:auto;
}
.products-summary-name{font-size:24px;font-weight:800;color:#1f2a44;line-height:1.15}
.products-summary-code{margin-top:4px;color:#4c5d80;font-size:13px;font-weight:700}
.products-summary-status{margin-top:8px}
.products-summary-grid{margin-top:10px;display:grid;grid-template-columns:1fr 1fr;gap:10px}
.products-summary-grid label{display:block;font-size:12px;color:#65728d;font-weight:700;margin-bottom:2px}
.products-summary-grid strong{font-size:14px;color:#1f2a44}
.products-detail-card{
  padding:0;
  display:flex;
  flex-direction:column;
  min-height:460px;
  height:460px;
}
.products-tabs-pager{
  display:grid;
  grid-template-columns:30px minmax(0,1fr) 30px;
  align-items:stretch;
  gap:0;
}
.products-tabs-nav{
  border:1px solid #cfd7e8;
  background:linear-gradient(180deg,#ffffff 0%, #edf3ff 100%);
  color:#304164;
  font-size:17px;
  font-weight:700;
  cursor:pointer;
  line-height:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0;
}
.products-tabs-nav:disabled{
  opacity:.45;
  cursor:not-allowed;
}
.products-tabs-nav[hidden]{
  visibility:hidden;
}
.products-detail-tabs-pager{
  padding:10px 12px;
  border-bottom:1px solid #e5ebf7;
  background:#f8faff;
}
.products-detail-tabs-pager .products-tabs-nav-prev{
  border-radius:8px 0 0 8px;
  border-right:none;
}
.products-detail-tabs-pager .products-tabs-nav-next{
  border-radius:0 8px 8px 0;
  border-left:none;
}
.products-detail-tabs{
  display:flex;
  align-items:stretch;
  gap:0;
  padding:0;
  border:1px solid #cfd7e8;
  border-radius:8px;
  overflow-x:auto;
  overflow-y:hidden;
  scrollbar-width:none;
  -ms-overflow-style:none;
}
.products-detail-tabs::-webkit-scrollbar{
  width:0;
  height:0;
  display:none;
}
.products-detail-tabs button{
  height:30px;
  border:none;
  border-right:1px solid #cfd7e8;
  border-radius:0;
  background:#fff;
  color:#324467;
  font-size:12px;
  font-weight:700;
  padding:0 10px;
  cursor:pointer;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  flex:0 0 160px;
}
.products-detail-tabs button:last-child{
  border-right:none;
}
.products-detail-tabs button::before{
  content:none;
}
.products-tab-icon{
  width:13px;
  height:13px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-right:6px;
  color:#506287;
  flex:0 0 auto;
}
.products-tab-icon svg{
  width:13px;
  height:13px;
  display:block;
  fill:currentColor;
}
.products-detail-tabs button.active{background:#e9f1ff;border-color:#a9beea;color:#1d4eaf}
.products-detail-tabs button.active .products-tab-icon{color:#1d4eaf}
.products-detail-scroll{
  flex:1;
  min-height:0;
  overflow:auto;
  scrollbar-gutter:stable both-edges;
}
.products-tab-panel{
  display:none;
  padding:12px;
  min-width:1180px;
}
.products-tab-panel.active{display:block}
.products-overview-sections{display:grid;gap:12px}
.products-overview-sections section{border:1px solid #e1e8f5;border-radius:10px;padding:10px;background:#fbfdff}
.products-overview-sections h4{margin:0 0 8px;font-size:14px;color:#1f2a44}
.products-kv-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}
.products-kv-item{border:1px solid #e6ecf8;border-radius:8px;padding:8px;background:#fff;min-height:60px}
.products-kv-item label{display:block;font-size:11px;color:#687791;font-weight:700;line-height:1.2}
.products-kv-item strong{display:block;margin-top:4px;font-size:13px;color:#1f2a44;line-height:1.35;white-space:pre-wrap;word-break:break-word}
.products-audit-value{max-width:280px;white-space:pre-wrap;word-break:break-word}
.products-detail-card .um-table-wrap{
  overflow:auto;
  scrollbar-gutter:stable both-edges;
}
.products-detail-card .um-table{
  min-width:1180px;
}

/* Products window-like modals */
.products-window-modal .um-modal-backdrop{
  background:
    radial-gradient(120% 90% at 50% 0%, rgba(93,118,177,.26) 0%, rgba(16,26,48,.62) 65%, rgba(10,16,30,.72) 100%);
  backdrop-filter:blur(2px);
}
.products-window-panel{
  border-radius:12px;
  border:1px solid #93a7cf;
  background:#f8fbff;
  box-shadow:
    0 34px 80px rgba(10,20,40,.46),
    0 4px 14px rgba(30,58,118,.24),
    inset 0 0 0 1px rgba(255,255,255,.65);
  overflow:auto;
  max-height:90vh;
}
.products-window-panel::before{
  content:'';
  display:block;
  height:3px;
  background:linear-gradient(90deg,#3d6fd7 0%, #5a8ef3 40%, #7db1ff 100%);
}
.products-window-header{
  min-height:44px;
  padding:10px 12px;
  background:linear-gradient(180deg,#f5f8ff 0%, #e6edf9 55%, #dde8f7 100%);
  border-bottom:1px solid #c7d4ea;
  position:sticky;
  top:0;
  z-index:2;
}
.products-window-title-wrap{
  min-width:0;
  display:flex;
  align-items:center;
  gap:8px;
}
.products-window-title-wrap h3{
  margin:0;
  font-size:16px;
  line-height:1.2;
  color:#1f2a44;
  font-weight:800;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.products-window-dots{
  display:inline-flex;
  align-items:center;
  gap:5px;
  flex:0 0 auto;
}
.products-window-dots .dot{
  width:10px;
  height:10px;
  border-radius:50%;
  display:inline-block;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.72), 0 1px 1px rgba(0,0,0,.18);
}
.products-window-dots .dot-red{background:linear-gradient(180deg,#ff9f95,#f05e55)}
.products-window-dots .dot-yellow{background:linear-gradient(180deg,#ffe08d,#f2bf40)}
.products-window-dots .dot-green{background:linear-gradient(180deg,#8fe4a9,#3fbf68)}
.products-window-close{
  width:30px;
  height:28px;
  border:1px solid #c7d2e8;
  border-radius:8px;
  background:linear-gradient(180deg,#ffffff 0%, #edf3ff 100%);
  color:#42567f;
  font-size:20px;
  line-height:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0;
  transition:background .15s ease, box-shadow .15s ease, color .15s ease;
}
.products-window-close:hover{
  background:linear-gradient(180deg,#ffffff 0%, #e2ecff 100%);
  color:#1f2a44;
  box-shadow:0 4px 10px rgba(47,99,221,.18);
}
.products-window-close:active{
  box-shadow:inset 0 1px 3px rgba(20,38,78,.2);
}
.products-window-panel .um-modal-content{
  background:linear-gradient(180deg,#fbfdff 0%, #f4f8ff 100%);
  padding:16px 18px;
  overflow:auto;
}
.products-window-panel .um-modal-footer{
  background:linear-gradient(180deg,#f6f9ff 0%, #edf3ff 100%);
  border-top:1px solid #d4dff3;
  padding:12px 18px;
  position:sticky;
  bottom:0;
  z-index:2;
}
.products-window-panel .um-form-grid label span{
  font-size:12px;
  color:#4e6289;
  font-weight:700;
}
.products-window-panel .um-form-grid input,
.products-window-panel .um-form-grid select,
.products-window-panel .um-form-grid textarea{
  border:1px solid #c7d4ec;
  border-radius:8px;
  background:#fff;
  color:#1f2a44;
  box-shadow:inset 0 1px 2px rgba(15,23,42,.04);
}
.products-window-panel .um-form-grid textarea{
  padding:9px 11px;
}
.products-window-panel .um-form-grid input:focus,
.products-window-panel .um-form-grid select:focus,
.products-window-panel .um-form-grid textarea:focus{
  outline:none;
  border-color:#86a3de;
  box-shadow:0 0 0 2px rgba(47,99,221,.14);
}
.products-attach-search-row{
  display:flex;
  align-items:center;
  gap:8px;
}
.products-attach-search-row input{
  flex:1;
}
.products-window-panel #productsAttachDocumentId{
  min-height:180px;
  padding:8px;
}
.products-modal-toolbar{
  display:flex;
  justify-content:flex-end;
  margin-bottom:8px;
}
