html,body,#root{color:#0f172a;background:#f8fafc;min-height:100vh;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Helvetica Neue,sans-serif}*,:before,:after{box-sizing:border-box}a{color:inherit}.portal-layout{min-height:100vh;display:flex}.portal-sidebar{z-index:100;background:#fff;border-right:1px solid #e2e8f0;flex-direction:column;width:220px;min-height:100vh;display:flex;position:fixed;top:0;bottom:0;left:0;overflow-y:auto}.portal-sidebar-logo{border-bottom:1px solid #e2e8f0;align-items:center;gap:10px;height:56px;padding:0 18px;display:flex}.portal-sidebar-logo-icon{color:#2563eb;font-size:22px}.portal-sidebar-logo-text{color:#0f172a;font-size:15px;font-weight:600}.portal-sidebar-menu{margin:0;padding:12px 8px;list-style:none}.portal-sidebar-menu-item{border-radius:6px;margin-bottom:2px}.portal-sidebar-menu-item a{color:#334155;border-radius:6px;align-items:center;gap:10px;padding:8px 12px;font-size:14px;text-decoration:none;transition:background .15s,color .15s;display:flex}.portal-sidebar-menu-item a:hover{color:#0f172a;background:#f1f5f9}.portal-sidebar-menu-item a.active{color:#1d4ed8;background:#eff6ff;font-weight:500}.portal-main{flex-direction:column;flex:1;min-width:0;min-height:100vh;margin-left:220px;display:flex}.portal-header{min-height:56px;padding:0 20px;padding-top:env(safe-area-inset-top,0);z-index:50;background:#fff;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;gap:12px;display:flex;position:sticky;top:0}.portal-header-hamburger{display:none}.portal-header-brand{flex:1;align-items:center;gap:8px;min-width:0;display:none}.portal-header-brand-icon{color:#2563eb;font-size:18px}.portal-header-brand-text{color:#0f172a;white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:600;overflow:hidden}.portal-header-actions{align-items:center;gap:12px;margin-left:auto;display:flex}.portal-header-email{color:#64748b;font-size:13px}.portal-sidebar-backdrop{z-index:99;background:#0f172a73;display:none;position:fixed;inset:0}.portal-content{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:24px 16px}@media (width<=768px){.portal-sidebar{padding-top:env(safe-area-inset-top,0);transition:transform .2s;transform:translate(-100%)}.portal-sidebar.open{transform:translate(0);box-shadow:0 0 24px #0f172a40}.portal-sidebar-backdrop{display:block}.portal-main{margin-left:0}.portal-header{padding:0 12px;padding-top:env(safe-area-inset-top,0)}.portal-header-hamburger{display:inline-flex}.portal-header-brand{display:flex}.portal-header-email,.portal-header-signout-text{display:none}.portal-content{padding:16px 12px}}.w-full{width:100%}.mb-0{margin-bottom:0}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.mt-0{margin-top:0}.mt-24{margin-top:24px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.gap-8{gap:8px}.gap-12{gap:12px}.text-center{text-align:center}.text-muted{color:#64748b}.text-xs{font-size:11px}.text-sm{font-size:12px}.text-base{font-size:13px}.text-subtle{color:#94a3b8}.text-red{color:#ef4444}.text-green{color:#10b981}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.tag-no-margin{margin:0}.tag-no-mr{margin-right:0}.tbl-compact .ant-table-tbody>tr>td,.tbl-compact .ant-table-thead>tr>th{padding:6px 10px!important;font-size:12px!important}.tbl-compact .ant-table-thead>tr>th{font-size:11px!important}.tbl-tag-xs .ant-tag{padding:0 6px!important;font-size:10px!important;line-height:16px!important}.tbl-cell-nowrap{white-space:nowrap;word-break:normal}.ant-table-tbody>tr>td{overflow-wrap:anywhere;word-break:normal}.quar-detail{padding:8px 0}.quar-detail-pre{white-space:pre-wrap;word-break:break-word;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;max-height:400px;margin:0;padding:12px;font-family:JetBrains Mono,ui-monospace,monospace;font-size:12px;overflow-y:auto}.quar-detail-html-warn{margin:12px 0 8px}.quar-search{max-width:360px;margin-bottom:12px}.quar-stats-row{margin-bottom:16px}.quar-html-frame{background:#fff;border:1px solid #e2e8f0;border-radius:6px;width:100%;height:480px;display:block}.quar-mobile-list{flex-direction:column;gap:10px;display:flex}.quar-mobile-card{cursor:pointer;transition:box-shadow .15s}.quar-mobile-card:active,.quar-mobile-card:focus-within{box-shadow:0 4px 12px #0f172a14}.quar-mobile-empty{text-align:center;padding:24px 8px}.quar-mobile-head{color:#64748b;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:11px;display:flex}.quar-mobile-score{font-variant-numeric:tabular-nums;font-size:14px;font-weight:700}.quar-mobile-date{font-variant-numeric:tabular-nums}.quar-mobile-subject{color:#0f172a;word-break:break-word;margin-bottom:4px;font-size:14px;font-weight:500;line-height:1.3}.quar-mobile-sender{color:#64748b;word-break:break-all;margin-bottom:10px;font-size:12px}.quar-mobile-actions{flex-direction:column;gap:6px;display:flex}.quar-mobile-actions>*,.quar-mobile-actions .ant-popover-disabled-compatible-wrapper{width:100%;display:block}.quar-mobile-actions .ant-btn{white-space:normal;width:100%;height:auto;min-height:32px;padding:6px 12px}.quar-mobile-detail{border-top:1px solid #f1f5f9;margin-top:12px;padding-top:12px}@media (width<=575px){.quar-stats-row .ant-statistic-title{font-size:11px}.quar-stats-row .ant-statistic-content{font-size:18px}.quar-search{max-width:100%}}.field-w-120{width:120px}.field-w-140{width:140px}.field-w-160{width:160px}.field-w-180{width:180px}.field-w-200{width:200px}.field-w-220{width:220px}.field-w-240{width:240px}.field-w-260{width:260px}.max-w-200{max-width:200px}.max-w-240{max-width:240px}.page-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.page-toolbar h1,.page-toolbar h2,.page-toolbar h3,.page-toolbar h4,.page-toolbar h5{margin:0}.auth-page{background:#f8fafc;justify-content:center;align-items:center;min-height:100vh;padding:16px;display:flex}.auth-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;width:100%;max-width:400px;padding:32px;box-shadow:0 1px 3px #00000008}.auth-logo-row{align-items:center;gap:12px;margin-bottom:28px;display:flex}.auth-logo-icon{color:#2563eb;font-size:28px}.auth-logo-title{color:#1e293b;font-size:16px;font-weight:700;line-height:1.2}.auth-logo-subtitle{color:#94a3b8;margin-top:2px;font-size:12px}.spinner-center{text-align:center;padding:24px}.score-cell{font-weight:500}
