:root{--space-8: 8px;--space-12: 12px;--space-16: 16px;--space-20: 20px;--space-24: 24px;--radius-8: 8px;--radius-10: 10px;--radius-12: 12px;--shadow-card-sm: 0 10px 24px rgba(15,23,42,.08);--shadow-card-md: 0 20px 50px rgba(15,23,42,.1);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:#101828;background-color:#f8fafc;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-height:100vh;background-color:inherit}a{color:inherit;text-decoration:none}a:hover{text-decoration:underline}button{font:inherit}main{min-height:100vh}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.page-header h1{margin:0;font-size:2rem;font-weight:600;color:#0f172a}.page-subtitle{margin:4px 0 0;color:#475467;font-size:.95rem}.empty-state{padding:48px;border:2px dashed #cbd5f5;border-radius:16px;background:#fff;color:#64748b;text-align:center}.empty-state p{margin:0}.action-button{padding:12px 18px;border-radius:10px;border:none;background:#0ea5e9;color:#fff;font-weight:600;cursor:pointer;box-shadow:0 10px 30px #0ea5e933}.action-button:hover{background:#0284c7}.card{background:#fff;border-radius:var(--radius-12);padding:var(--space-16) var(--space-20);box-shadow:var(--shadow-card-sm)}.section-title{font-size:.9rem;letter-spacing:.02em;text-transform:none;font-weight:600;color:#0f172ae6}.table-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;color:#475467;font-size:.95rem}.table-meta__status{color:#0f172a;font-weight:500}.campaign-table{width:100%;border-collapse:collapse}.campaign-table th{text-align:left;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;color:#64748b;padding-bottom:12px}.campaign-table td{padding:14px 0;border-top:1px solid #e2e8f0;color:#0f172a}.campaign-row{cursor:pointer;transition:background-color .15s ease}.campaign-row:hover{background:#f1f5f9}.status-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:.85rem;text-transform:capitalize;background:#e0f2fe;color:#0369a1}.status-chip--completed{background:#dcfce7;color:#15803d}.status-chip--in_progress{background:#fef3c7;color:#b45309}.status-chip--high{background:#dcfce7;color:#15803d}.status-chip--average{background:#fde68a;color:#92400e}.status-chip--low{background:#fee2e2;color:#b91c1c}.toast-host{position:fixed;right:16px;bottom:16px;display:flex;flex-direction:column;gap:10px;z-index:10000}.toast{background:#111827;color:#f9fafb;padding:12px 14px;border-radius:10px;min-width:260px;box-shadow:0 10px 30px #00000040}.toast__title{display:block;margin-bottom:4px}.toast--success{background:#065f46}.toast--error{background:#7f1d1d}.toast--info{background:#1f2937}.empty-state.error{border-color:#fecaca;background:#fee2e2;color:#b91c1c}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px}.metric-card{background:#fff;border-radius:var(--radius-12);padding:14px 16px;box-shadow:var(--shadow-card-sm);display:flex;flex-direction:column;gap:6px}.metric-card__label{font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;color:#64748b}.metric-card__value{font-size:1.75rem;font-weight:600;color:#0f172a}.metric-card__helper{color:#475467;font-size:.95rem}.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:.85rem;margin:4px 6px 0 0}.chip--positive{background:#dcfce7;color:#065f46}.chip--negative{background:#fee2e2;color:#991b1b}.chip--impact-high{outline:2px solid rgba(34,197,94,.6)}.chip--impact-very\ high{outline:2px solid rgba(16,185,129,.8)}.chip--impact-medium{outline:2px solid rgba(250,204,21,.7)}.tabs{display:inline-flex;gap:8px;margin-bottom:16px;background:#e2e8f0;padding:6px;border-radius:999px}.tab{border:none;background:transparent;padding:8px 16px;border-radius:999px;font-weight:500;color:#475467;cursor:pointer}.tab--active{background:#fff;color:#0f172a;box-shadow:0 10px 30px #0f172a1a}.tab-panel{display:flex;flex-direction:column;gap:20px}.grid-two{display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.list-stack{margin-top:16px}.list-stack h4{margin:0 0 8px;font-size:1rem;color:#0f172a}.list-stack ul{margin:0;padding-left:18px;color:#475467}.metric-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px;color:#0f172a}.metric-list li{display:flex;justify-content:space-between;font-size:.95rem}.thread-list{display:flex;flex-direction:column;gap:16px}.thread-card{background:#f8fafc;border-radius:var(--radius-12);padding:var(--space-16);border:1px solid #e2e8f0}.thread-card header{display:flex;justify-content:space-between;margin-bottom:12px;color:#0f172a}.thread-card pre{margin:0;white-space:pre-wrap;font-family:Inter,sans-serif;color:#475467}.thread-tone{color:#64748b}.summary-list{list-style:none;margin:8px 0 0;padding:0}.summary-list li{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-top:1px solid #e2e8f0}.rating-chip{display:inline-flex;align-items:center;padding:6px 12px;border-radius:999px;font-weight:600;font-size:.9rem}.rating-chip--high{background:#dcfce7;color:#166534}.rating-chip--medium{background:#fef9c3;color:#854d0e}.rating-chip--low{background:#fee2e2;color:#991b1b}.pill-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-12)}.metric-pill{display:grid;grid-template-rows:auto auto auto;gap:2px;background:#fff;border-radius:var(--radius-12);padding:var(--space-12) var(--space-14, 14px);border:1px solid #e2e8f0}.metric-pill span{color:#475467;font-size:.9rem}.metric-pill strong{color:#0f172a;font-size:1.2rem}.metric-pill small{color:#64748b}.inbox-layout{display:grid;grid-template-columns:260px 1fr;gap:var(--space-16)}.inbox-roster{background:#fff;border:1px solid #e2e8f0;border-radius:var(--radius-12);padding:var(--space-8)}.inbox-roster-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:var(--radius-10);cursor:pointer}.inbox-roster-item:hover{background:#f1f5f9}.inbox-roster-item--active{background:#e2e8f0}.skeleton{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0 37%,#f1f5f9 63%);background-size:400% 100%;animation:skeleton-loading 1.4s ease infinite;border-radius:10px}.skeleton--text{height:14px}.skeleton--card{height:90px}@keyframes skeleton-loading{0%{background-position:100% 50%}to{background-position:0 50%}}@media (max-width: 720px){.page-header{flex-direction:column;align-items:flex-start;gap:16px}.tabs{width:100%;justify-content:space-between}}.modal-overlay{position:fixed;inset:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;padding:32px;z-index:1000}.modal{width:min(720px,100%);background:#fff;border-radius:16px;box-shadow:0 20px 64px #0f172a40;display:flex;flex-direction:column;max-height:calc(100vh - 64px)}.modal__header{display:flex;align-items:flex-start;justify-content:space-between;padding:24px 28px;border-bottom:1px solid #e2e8f0}.modal__header h2{margin:0;font-size:1.5rem;color:#0f172a}.modal__header p{margin:6px 0 0;color:#475467}.modal__close{border:none;background:transparent;font-size:1.5rem;color:#64748b;cursor:pointer}.modal__body{display:flex;flex-direction:column;gap:18px;padding:24px 28px 28px;overflow-y:auto}.modal__field{display:flex;flex-direction:column;gap:8px}.modal__field span{font-weight:500;color:#1f2937}.modal__field input,.modal__field textarea{padding:12px 14px;border-radius:10px;border:1px solid #cbd5e1;font:inherit;resize:vertical}.modal__field textarea{line-height:1.45}.modal__field input:focus,.modal__field textarea:focus{outline:2px solid #6366f1;border-color:#6366f1}.modal__hint{margin-top:4px;color:#64748b;font-size:.85rem}.modal__checkbox{display:flex;align-items:center;gap:12px;font-size:.95rem;color:#1f2937}.modal__error{background:#fee2e2;color:#b91c1c;padding:12px 14px;border-radius:8px;font-size:.95rem}.modal__footer{margin-top:8px;display:flex;justify-content:flex-end;gap:12px}.modal__tabs{display:inline-flex;gap:8px;margin-bottom:8px}.modal__tab{padding:8px 12px;border-radius:999px;border:1px solid #cbd5e1;background:#fff;color:#0f172a;cursor:pointer}.modal__tab--active{background:#eef2ff;border-color:#6366f1;color:#3730a3}.mode-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-bottom:8px}.mode-card{appearance:none;border:2px solid #e2e8f0;border-radius:14px;background:#fff;padding:14px;text-align:left;cursor:pointer}.mode-card--active{border-color:#6366f1;box-shadow:0 10px 24px #4f46e526}.mode-card__icon{font-size:20px}.mode-card__title{font-weight:600;margin-top:6px}.mode-card__desc{color:#64748b;margin-top:2px}.dropzone{margin-top:8px;border:2px dashed #cbd5e1;border-radius:12px;padding:20px;text-align:center;color:#64748b}.modal__button{padding:10px 16px;border-radius:8px;border:1px solid #cbd5f5;background:#fff;color:#0f172a;cursor:pointer}.modal__button--primary{background:#6366f1;border-color:#6366f1;color:#fff}.modal__button:disabled{opacity:.6;cursor:not-allowed}.app-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh;background:#f8fafc}.app-shell__sidebar{display:flex;flex-direction:column;gap:24px;padding:24px;background:#0f172a;color:#e2e8f0}.app-shell__brand{font-size:1.25rem;font-weight:600;letter-spacing:.02em}.app-shell__nav{display:flex;flex-direction:column;gap:12px}.app-shell__nav-link{padding:10px 12px;border-radius:8px;color:#cbd5f5;transition:background-color .2s ease,color .2s ease}.app-shell__nav-link:hover{background:#94a3b840;color:#fff}.app-shell__nav-link--active{background:#6366f1;color:#fff}.app-shell__cta{margin-top:auto;padding:12px;border:none;border-radius:8px;background:#6366f1;color:#fff;font-weight:600;cursor:pointer;transition:background-color .2s ease}.app-shell__cta:hover{background:#4f46e5}.app-shell__main{padding:32px;background:#f8fafc}@media (max-width: 960px){.app-shell{grid-template-columns:1fr}.app-shell__sidebar{flex-direction:row;align-items:center;justify-content:space-between}.app-shell__nav{flex-direction:row}.app-shell__cta{margin-top:0}}
