:root{--brand-ink: #2f3030;--brand-coral: #ee8d84;--brand-lilac: #7b61ff;--brand-cyan: #27d7ff;--success: #19b86a;--green: var(--brand-coral);--green-light: #fff0ed;--green-xlight: #fff8f6;--blue: var(--brand-lilac);--blue-light: #f0ecff;--blue-xlight: #f8f6ff;--gray-50: #fafafa;--gray-100: #f4f4f5;--gray-200: #e4e4e7;--gray-300: #d4d4d8;--gray-400: #a1a1aa;--gray-500: #71717a;--gray-600: #52525b;--gray-700: #3f3f46;--gray-800: #27272a;--red: #e53e3e;--red-light: #fdecec;--orange: #f59e0b;--orange-light: #fef3e2;--yellow: #d69e2e;--yellow-light: #fdf6e3;--surface: #ffffff;--sidebar-w: 248px;--header-h: 64px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--shadow-card: 0 1px 3px rgba(47, 48, 48, .06), 0 1px 2px rgba(47, 48, 48, .08);--shadow-modal: 0 12px 32px rgba(47, 48, 48, .18)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--brand-ink);background:var(--gray-50);-webkit-font-smoothing:antialiased}a{color:inherit}button{font-family:inherit}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--brand-ink);color:#fff;display:flex;flex-direction:column;padding:20px 14px;gap:4px}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:10px 12px 22px;font-weight:700;font-size:18px;letter-spacing:.02em}.sidebar-brand .logo-mark{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--brand-coral),var(--brand-lilac));display:flex;align-items:center;justify-content:center;font-weight:800;color:var(--brand-ink)}.nav-link{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);color:#ffffffb3;text-decoration:none;font-size:14px;font-weight:500;transition:background .15s,color .15s}.nav-link:hover{background:#ffffff0f;color:#fff}.nav-link.active{background:#ee8d8429;color:var(--brand-coral)}.nav-icon.ui-icon{width:18px;height:18px;flex-shrink:0}.sidebar-footer{margin-top:auto;padding-top:16px;border-top:1px solid rgba(255,255,255,.08)}.sidebar-toggle{display:flex;align-items:center;justify-content:center;width:100%;padding:6px;background:#ffffff0d;border:none;border-radius:var(--radius-sm);color:#ffffff73;cursor:pointer;margin-bottom:8px;transition:background .15s,color .15s}.sidebar-toggle:hover{background:#ffffff1a;color:#fff}.sidebar-toggle .ui-icon{width:15px;height:15px}.sidebar--collapsed{width:64px;padding:20px 8px}.sidebar--collapsed .sidebar-brand{justify-content:center;padding:10px 4px 22px}.sidebar--collapsed .nav-link{justify-content:center;padding:10px;gap:0}.main-area{flex:1;display:flex;flex-direction:column;min-width:0}.topbar{height:var(--header-h);flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:0 28px;background:#fff;border-bottom:1px solid var(--gray-200)}.topbar-title{font-size:18px;font-weight:700}.topbar-user{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--gray-600)}.content{flex:1;padding:28px;overflow-y:auto}.card{background:#fff;border-radius:var(--radius-md);border:1px solid var(--gray-200);box-shadow:var(--shadow-card);padding:20px}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}@media (max-width: 1100px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}.kpi-card{background:#fff;border-radius:var(--radius-md);border:1px solid var(--gray-200);box-shadow:var(--shadow-card);padding:18px 20px;position:relative;overflow:hidden}.kpi-card .kpi-label{font-size:13px;color:var(--gray-500);font-weight:600;margin-bottom:6px}.kpi-card .kpi-value{font-size:26px;font-weight:800;letter-spacing:-.01em}.kpi-card .kpi-delta{font-size:12px;font-weight:600;margin-top:6px}.kpi-icon.ui-icon{position:absolute;right:14px;top:14px;width:26px;height:26px;opacity:.18}.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;border:1px solid transparent;cursor:pointer;transition:filter .15s,background .15s,border-color .15s;white-space:nowrap}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--brand-coral),var(--brand-lilac));color:#fff;box-shadow:0 4px 12px #7b61ff40}.btn-primary:hover:not(:disabled){filter:brightness(1.05)}.btn-secondary{background:var(--gray-100);color:var(--brand-ink)}.btn-secondary:hover:not(:disabled){background:var(--gray-200)}.btn-outline{background:transparent;border-color:var(--gray-300);color:var(--brand-ink)}.btn-outline:hover:not(:disabled){border-color:var(--brand-lilac);color:var(--brand-lilac)}.btn-danger{background:var(--red-light);color:var(--red)}.btn-danger:hover:not(:disabled){filter:brightness(.97)}.btn-sm{padding:6px 12px;font-size:13px}.btn-icon{padding:8px}.btn .ui-icon{width:16px;height:16px}.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:700}.badge-red{background:var(--red-light);color:var(--red)}.badge-blue{background:var(--blue-light);color:var(--blue)}.badge-green{background:var(--green-light);color:var(--success)}.badge-orange{background:var(--orange-light);color:var(--orange)}.badge-yellow{background:var(--yellow-light);color:var(--yellow)}.badge-gray{background:var(--gray-100);color:var(--gray-600)}table{width:100%;border-collapse:collapse;font-size:14px}thead th{text-align:left;background:var(--gray-50);color:var(--gray-500);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.04em;padding:10px 14px;border-bottom:1px solid var(--gray-200)}tbody td{padding:12px 14px;border-bottom:1px solid var(--gray-100);vertical-align:middle}tbody tr:hover{background:var(--gray-50)}tbody tr.clickable{cursor:pointer}.form-group{margin-bottom:16px}.form-label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--gray-700)}.form-input,.form-select,.form-textarea{width:100%;padding:10px 12px;border:1px solid var(--gray-300);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;background:#fff;color:var(--brand-ink)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--brand-lilac);box-shadow:0 0 0 3px #7b61ff1f}.form-hint{font-size:12px;color:var(--gray-500);margin-top:4px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}@media (max-width: 720px){.form-row,.form-row-3{grid-template-columns:1fr}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#2f303073;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-modal);width:100%;max-height:90vh;overflow-y:auto;padding:24px}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.modal-title{font-size:18px;font-weight:700}.modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;padding-top:16px;border-top:1px solid var(--gray-200)}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--gray-200);margin-bottom:18px}.tab{padding:10px 16px;font-size:14px;font-weight:600;color:var(--gray-500);cursor:pointer;border-bottom:2px solid transparent;background:none;border-top:none;border-left:none;border-right:none}.tab.active{color:var(--brand-lilac);border-color:var(--brand-lilac)}.workflow-phase{display:flex;align-items:flex-start;gap:14px;padding:16px 0}.phase-icon{width:40px;height:40px;border-radius:var(--radius-sm);background:var(--blue-light);color:var(--brand-lilac);display:flex;align-items:center;justify-content:center;flex-shrink:0}.phase-connector{width:2px;flex:1;background:var(--gray-200);margin:4px 0 4px 19px}.phase-info{flex:1}.phase-name{font-weight:700;font-size:14px;margin-bottom:2px}.timeline{position:relative}.timeline-item{display:flex;gap:12px;padding-bottom:18px;position:relative}.timeline-item:not(:last-child):before{content:"";position:absolute;left:4px;top:14px;bottom:0;width:1px;background:var(--gray-200)}.timeline-dot{width:10px;height:10px;border-radius:50%;background:var(--brand-lilac);margin-top:4px;flex-shrink:0}.timeline-dot.green{background:var(--success)}.timeline-dot.red{background:var(--red)}.timeline-dot.orange{background:var(--orange)}.timeline-body{flex:1}.timeline-title{font-size:13px;font-weight:600}.timeline-time{font-size:12px;color:var(--gray-400)}.timeline-msg{font-size:13px;color:var(--gray-600);margin-top:2px}.kanban{display:flex;gap:16px;overflow-x:auto;padding-bottom:8px}.kanban-col{min-width:260px;flex-shrink:0;background:var(--gray-50);border-radius:var(--radius-md);padding:12px}.kanban-col-title{display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500);margin-bottom:10px;padding:0 4px}.kanban-count{background:var(--gray-200);color:var(--gray-600);border-radius:999px;padding:1px 8px;font-size:11px}.kanban-card{background:#fff;border-radius:var(--radius-sm);border:1px solid var(--gray-200);padding:12px;margin-bottom:10px;font-size:13px;box-shadow:var(--shadow-card);cursor:pointer}.kanban-card:hover{border-color:var(--brand-lilac)}.kanban-card .kc-name{font-weight:700;margin-bottom:4px}.kanban-card .kc-meta{color:var(--gray-500);font-size:12px}.qr-grid{display:grid;grid-template-columns:repeat(21,1fr);gap:1px;width:210px;height:210px;background:#fff;padding:8px;border-radius:var(--radius-sm);border:1px solid var(--gray-200)}.qr-cell.active{background:var(--brand-ink)}.wa-preview{background:#ece5dd;border-radius:var(--radius-md);padding:16px}.wa-msg{background:#fff;border-radius:10px;padding:10px 12px;font-size:13px;max-width:80%;margin-bottom:8px;box-shadow:var(--shadow-card);white-space:pre-wrap}.wa-msg.outgoing{background:#d9fdd3;margin-left:auto}.text-green{color:var(--success)}.text-blue{color:var(--brand-lilac)}.text-red{color:var(--red)}.text-muted{color:var(--gray-500)}.font-bold{font-weight:700}.text-xs{font-size:12px}.text-sm{font-size:13px}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.mb-4{margin-bottom:4px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-20{margin-bottom:20px}.ml-8{margin-left:8px}.gap-6{gap:6px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.flex{display:flex}.flex-center{display:flex;align-items:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.col{display:flex;flex-direction:column}.section-divider{border:none;border-top:1px solid var(--gray-200);margin:20px 0}.grid-2{display:grid;grid-template-columns:1.4fr 1fr;gap:20px}@media (max-width: 1100px){.grid-2{grid-template-columns:1fr}}.ui-icon{width:16px;height:16px;display:inline-block;vertical-align:middle;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.login-screen{min-height:100vh;display:flex}.login-hero{flex:1.1;background:linear-gradient(135deg,var(--brand-ink),#44403c);color:#fff;display:flex;flex-direction:column;justify-content:center;padding:60px}.login-hero h1{font-size:40px;font-weight:800;margin:0 0 12px}.login-hero p{color:#ffffffb3;font-size:16px;max-width:420px}.login-stats{display:flex;gap:16px;margin-top:40px}.login-stat{background:#ffffff0f;border-radius:var(--radius-md);padding:16px 20px;flex:1}.login-stat .stat-value{font-size:22px;font-weight:800;color:var(--brand-coral)}.login-stat .stat-label{font-size:12px;color:#fff9;margin-top:4px}.login-form-panel{flex:1;display:flex;align-items:center;justify-content:center;padding:40px;background:#fff}.login-form-card{width:100%;max-width:380px}.login-form-card h2{font-size:24px;font-weight:800;margin-bottom:6px}.login-form-card .subtitle{color:var(--gray-500);font-size:14px;margin-bottom:28px}.toast-stack{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:10px;z-index:2000}.toast{padding:12px 16px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;color:#fff;box-shadow:var(--shadow-modal);min-width:220px;animation:toast-in .2s ease-out}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.toast.success{background:linear-gradient(135deg,var(--success),#0e8a4f)}.toast.error{background:linear-gradient(135deg,var(--red),#b83333)}.toast.warning{background:linear-gradient(135deg,var(--orange),#c97a06)}.toast.info{background:linear-gradient(135deg,var(--brand-lilac),#5a45c9)}.empty-state{text-align:center;padding:40px 20px;color:var(--gray-500)}.pill-input{display:flex;align-items:center;gap:8px;border:1px solid var(--gray-300);border-radius:999px;padding:8px 16px;background:#fff}.pill-input input{border:none;outline:none;font-size:14px;flex:1}.page-title{font-size:22px;font-weight:800;margin-bottom:4px}.page-subtitle{color:var(--gray-500);font-size:14px;margin-bottom:24px}.score-bar-track{height:6px;background:var(--gray-200);border-radius:999px;overflow:hidden}.score-bar-fill{height:100%;border-radius:999px;background:linear-gradient(135deg,var(--brand-coral),var(--brand-lilac))}.qr-frame{width:220px;height:220px;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-md);padding:12px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-card)}.qr-grid{display:grid;grid-template-columns:repeat(21,1fr);grid-template-rows:repeat(21,1fr);width:100%;height:100%}.qr-cell{background:transparent}.qr-cell.on{background:var(--brand-ink)}.wa-preview{background:#e5ddd5;border-radius:var(--radius-md);padding:16px;display:flex;flex-direction:column;gap:8px;min-height:200px}.wa-msg{max-width:80%;padding:8px 12px;border-radius:var(--radius-sm);font-size:13px;line-height:1.4;background:#fff;align-self:flex-start;box-shadow:var(--shadow-card)}.wa-msg.outbound{background:#d9fdd3;align-self:flex-end}.wa-msg-time{display:block;margin-top:4px;font-size:11px;color:var(--gray-500);text-align:right}.status-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:999px;font-weight:700;font-size:13px}.status-pill.connected{background:#19b86a1f;color:var(--success)}.status-pill.disconnected{background:#ee5c5c1f;color:var(--red)}.status-pill.pending{background:#ffb80024;color:var(--orange)}
