@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--donut-progress:0}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.relative{position:relative}.static{position:static}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.flex{display:flex}.grid{display:grid}.table{display:table}.min-h-screen{min-height:100vh}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.rounded{border-radius:.25rem}.border{border-style:var(--tw-border-style);border-width:1px}.bg-\[\#f4f7f3\]{background-color:#f4f7f3}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}}:root{--bg:#f4f7f3;--panel:#fff;--text:#172033;--muted:#64748b;--line:#dfe7e1;--green:#16a34a;--green2:#22c55e;--greenSoft:#e8f6ee;--blue:#2563eb;--blueSoft:#60a5fa;--orange:#f59e0b;--red:#dc2626;--redDark:#991b1b;--gray:#d6dfd9;--shadow:0 10px 26px #0f172a0f}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;margin:0;font-family:Be Vietnam Pro,Arial,sans-serif;font-size:16px;font-weight:350}.app{align-items:flex-start;min-height:100vh;display:flex}.sidebar{border-right:1px solid var(--line);background:#fff;width:265px;height:100vh;padding:22px 18px;position:sticky;top:0}.brand{align-items:center;gap:12px;margin-bottom:26px;display:flex}.logo{color:#fff;background:linear-gradient(135deg,#14532d,#166534);border-radius:15px;place-items:center;width:46px;height:46px;font-weight:700;display:grid}.logo-img{object-fit:contain;flex:0 0 46px;width:46px;height:46px}.brand h2{margin:0;font-size:18px;font-weight:600}.brand p{color:var(--muted);margin:3px 0 0;font-size:13px}.nav-label{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin:18px 8px 10px;font-size:12px;font-weight:600}.nav-btn{cursor:pointer;color:#334155;text-align:left;background:0 0;border:none;border-radius:14px;align-items:center;gap:10px;width:100%;margin-bottom:8px;padding:13px 14px;font-family:inherit;font-size:14px;font-weight:350;display:flex}.nav-btn.active{background:var(--greenSoft);color:#15803d;font-weight:550}.main{flex:1;min-width:0;max-width:1760px;min-height:100vh;padding:26px;overflow-x:clip}.hero{border:1px solid var(--line);box-shadow:var(--shadow);background:linear-gradient(135deg,#fff,#f9fcf9);border-radius:28px;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:18px;padding:24px;display:flex}.hero h1{margin:0 0 8px;font-size:28px;font-weight:650}.hero p{color:var(--muted);margin:0;font-size:14px;line-height:1.6}.hero-actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.btn{cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #cbd8ce;border-radius:13px;height:42px;padding:0 16px;font-family:inherit;font-weight:550}.btn.primary{color:#fff;background:linear-gradient(135deg,#16a34a,#15803d);border-color:#15803d}.btn:disabled{opacity:.45;cursor:not-allowed}.alert{color:#9a3412;background:#fff7ed;border:1px dashed #fed7aa;border-radius:16px;margin-bottom:16px;padding:12px 14px;font-size:14px}.grid-kpi{grid-template-columns:repeat(8,minmax(150px,1fr));gap:14px;margin-bottom:16px;display:grid}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;min-width:0;margin-bottom:16px;display:grid}.card{background:var(--panel);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:22px;margin-bottom:16px;padding:18px}.kpi{min-height:118px;margin-bottom:0;position:relative;overflow:hidden}.kpi:after{content:"";opacity:.55;background:var(--greenSoft);border-radius:999px;width:110px;height:110px;position:absolute;top:-35px;right:-35px}.kpi .label{z-index:1;align-items:center;gap:8px;margin-bottom:10px;font-size:13px;font-weight:500;display:flex;position:relative}.dot{background:var(--green);border-radius:999px;flex:none;width:8px;height:8px;display:inline-block}.dot.blue{background:var(--blue)}.dot.orange{background:var(--orange)}.dot.red{background:var(--red)}.dot.green{background:var(--green)}.kpi .value{z-index:1;margin-bottom:4px;font-size:26px;font-weight:650;position:relative}.kpi .desc{z-index:1;color:var(--muted);font-size:13px;line-height:1.45;position:relative}.card-title{margin:0;font-size:18px;font-weight:700}.card-sub{color:var(--muted);margin:6px 0 14px;font-size:14px;line-height:1.55}.donut-layout{grid-template-columns:300px 1fr;align-items:center;gap:20px;min-height:310px;display:grid}.donut-wrap{width:280px;height:280px;margin:0 auto;position:relative}.donut{border-radius:50%;width:280px;height:280px;position:relative}.donut:after{content:"";box-shadow:inset 0 0 0 1px var(--line);z-index:1;background:#fff;border-radius:50%;position:absolute;inset:54px}.donut-center{z-index:2;text-align:center;place-items:center;padding:0 24px;display:grid;position:absolute;inset:0}.donut-center .big{font-size:34px;font-weight:650}.donut-center .small{color:var(--muted);margin-top:5px;font-size:12px}.legend{gap:10px;display:grid}.legend-item{border-bottom:1px dashed #e2e8f0;grid-template-columns:1fr auto;align-items:center;gap:14px;padding-bottom:10px;font-size:14px;display:grid}.legend-left{align-items:center;gap:9px;display:flex}.legend-dot{border-radius:50%;flex:none;width:11px;height:11px}.legend-val{text-align:right;font-weight:550}.insight{color:#475569;background:#fafcfb;border:1px dashed #d7e6db;border-radius:16px;margin-top:13px;padding:12px 14px;font-size:14px;line-height:1.6}.table-wrap{border:1px solid var(--line);background:#fff;border-radius:18px;max-width:100%;overflow:auto visible}table{border-collapse:collapse;width:100%;min-width:1100px}th,td{text-align:left;white-space:nowrap;border-bottom:1px solid #edf1ee;padding:12px 14px;font-size:14px}th{z-index:1;color:#15803d;background:#f6faf7;font-size:13px;font-weight:550;position:sticky;top:0}tbody tr:hover td{background:#fbfdfb}.pill{border-radius:999px;padding:5px 10px;font-size:12px;font-weight:550;display:inline-flex}.pill.green{color:#15803d;background:#e8f6ee}.pill.red{color:var(--red);background:#fdecef}.pill.orange{color:var(--orange);background:#fff7ed}.pill.blue{color:var(--blue);background:#ebf1ff}.loading{text-align:center;color:var(--muted);padding:70px;font-size:20px;font-weight:500}.filters{grid-template-columns:1.2fr 1fr 1fr 1fr 1fr auto auto;align-items:end;gap:12px;margin-bottom:16px;display:grid}.field label{color:#334155;margin-bottom:7px;font-size:13px;font-weight:500;display:block}.input,.select{background:#fff;border:1px solid #cbd8ce;border-radius:13px;outline:none;width:100%;height:42px;padding:0 12px;font-family:inherit;font-size:14px}.input:focus,.select:focus{border-color:var(--green2);box-shadow:0 0 0 3px #22c55e1f}.chart-card{background:#fff;border:1px solid #dfe7df;border-radius:22px;margin-bottom:16px;padding:18px 20px 16px;box-shadow:0 4px 18px #10200f0a}.chart-title{color:#172033;margin:0 0 6px;font-size:20px;font-weight:700;line-height:1.2}.chart-sub{color:#64748b;margin:0 0 12px;font-size:14px;line-height:1.5}.chart-wrap{background:#fcfdfc;border:1px solid #dfe8dc;border-radius:20px;padding:10px 14px 6px;overflow:hidden}.chart-note{color:#63708a;background:#fbfdfb;border:1px dashed #d8e6d7;border-radius:16px;margin-top:12px;padding:12px 14px;font-size:14px;line-height:1.5}.page-actions{justify-content:space-between;align-items:center;gap:10px;margin-top:12px;display:flex}.status{color:#64748b;font-size:13px;font-weight:500}.hidden{display:none!important}@media (max-width:1650px){.grid-kpi{grid-template-columns:repeat(4,1fr)}}@media (max-width:1200px){.grid-kpi{grid-template-columns:repeat(2,1fr)}.grid-2,.donut-layout{grid-template-columns:1fr}.filters{grid-template-columns:1fr 1fr}}@media (max-width:700px){.app{display:block}.sidebar{width:100%;height:auto;position:relative}.main{padding:14px}.grid-kpi{grid-template-columns:1fr}.hero{display:block}.hero-actions{justify-content:flex-start;margin-top:14px}.filters{grid-template-columns:1fr}.donut-wrap,.donut{width:220px;height:220px}.donut:after{inset:42px}}.chart-status{color:#f59e0b;margin-left:6px}.relative{position:relative}.chart-svg{width:100%;height:auto;min-height:330px;display:block}.empty-chart{color:var(--muted);padding:24px}.chart-legend{color:#4a5974;flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:14px;margin-bottom:8px;font-size:14px;font-weight:500;display:flex}.chart-legend-item{align-items:center;gap:7px;display:inline-flex}.chart-legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;display:inline-block}.chart-legend-line-mark{flex-shrink:0;align-items:center;line-height:0;display:inline-flex}.chart-tooltip{z-index:9999;pointer-events:none;color:#172033;background:#fff;border:1px solid #d9e1ef;border-radius:14px;min-width:190px;padding:12px 14px;font-size:14px;line-height:1.45;position:fixed;box-shadow:0 10px 30px #1020331f}.chart-card.relative .chart-tooltip{z-index:30;position:absolute}.chart-tooltip-title{margin-bottom:8px;font-size:15px;font-weight:700}.chart-tooltip-row{justify-content:space-between;gap:16px;margin:4px 0;display:flex}.chart-tooltip-label{color:#55627b;align-items:center;gap:7px;display:inline-flex}.chart-tooltip-value{color:#172033;font-weight:700}.chart-tooltip-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.green-bg{background:#16a34a}.chart-loading{color:#64748b;background:#fafcfb;border:1px dashed #dfe7e1;border-radius:20px;justify-content:center;align-items:center;gap:12px;padding:48px 24px;font-size:15px;display:flex}.spinner{border:3px solid #e2e8f0;border-top-color:#16a34a;border-radius:50%;flex:none;width:22px;height:22px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.medium{font-weight:550}.muted-empty{color:#64748b;font-size:14px}.bar-list{gap:14px;display:grid}.bar-row{grid-template-columns:190px 1fr 70px;align-items:center;gap:12px;font-size:14px;display:grid}.bar-bg{background:#edf2ef;border-radius:999px;height:12px;overflow:hidden}.bar-fill{background:#16a34a;border-radius:999px;height:100%}.hourly-bars{gap:12px;margin-top:4px;display:grid}.hour-row{grid-template-columns:140px 1fr 100px;align-items:center;gap:12px;font-size:14px;display:grid}.hour-track{background:#eef4f0;border:1px solid #dfe7e1;border-radius:999px;height:18px;overflow:hidden}.hour-fill{background:linear-gradient(90deg,#16a34a,#22c55e);border-radius:999px;height:100%}.hour-value{color:#475569;text-align:right;white-space:nowrap;font-size:13px;font-weight:500}.detail-filters{grid-template-columns:1.2fr 1fr 1fr 1fr 1fr auto}.detail-actions{color:#334155;flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;margin-top:14px;font-size:14px;display:flex}.page-size{width:140px}@media (max-width:1200px){.detail-filters{grid-template-columns:1fr 1fr}.hour-row{grid-template-columns:125px 1fr 90px}}@media (max-width:700px){.detail-filters,.hour-row{grid-template-columns:1fr}.chart-svg{min-height:220px}}@media (max-width:1200px){.sidebar{width:220px;padding:16px 12px}.bar-row{grid-template-columns:130px 1fr 70px}.donut-wrap,.donut{width:220px;height:220px}.donut:after{inset:42px}.donut-center .big{font-size:28px}}@media (max-width:700px){.sidebar{padding:14px 10px}.sidebar .nav-label{margin:12px 4px 6px}.nav-btn{padding:10px;font-size:13px}.main{padding:12px}.hero{margin-bottom:12px;padding:16px}.hero h1{font-size:20px}.hero p{font-size:13px}.card{border-radius:16px;padding:14px}.card-title{font-size:16px}.chart-card{padding:14px}.chart-title{font-size:16px}.donut-layout{min-height:unset;flex-direction:column;align-items:center;gap:16px;display:flex}.legend-item{grid-template-columns:1fr auto;font-size:13px}.legend{width:100%}.bar-row{grid-template-columns:100px 1fr 60px;gap:8px;font-size:13px}.kpi .value{font-size:22px}.filters{gap:8px}.detail-actions{flex-wrap:wrap;gap:6px;font-size:13px}.page-size{width:120px}table{min-width:700px}th,td{padding:9px 10px;font-size:13px}}@property --donut-progress{syntax:"<number>";inherits:false;initial-value:0}@keyframes donutReveal{0%{--donut-progress:0}to{--donut-progress:1}}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes barGrow{0%{transform:scaleX(0)}to{transform:scaleX(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.hero{animation:.3s both fadeSlideUp}.alert{animation:.2s both fadeIn}.grid-kpi{animation:.25s both fadeIn}.grid-2{animation:.35s both fadeSlideUp}.card{transition:box-shadow .2s,transform .2s;animation:.35s both fadeSlideUp}.card:hover{transform:translateY(-2px);box-shadow:0 18px 44px #0f172a1a}.chart-card{transition:box-shadow .2s;animation:.35s both fadeSlideUp}.chart-card:hover{box-shadow:0 14px 36px #0f172a17}.donut{animation:1.1s cubic-bezier(.4,0,.2,1) both donutReveal}.grid-kpi .kpi:first-child{animation-delay:40ms}.grid-kpi .kpi:nth-child(2){animation-delay:80ms}.grid-kpi .kpi:nth-child(3){animation-delay:.12s}.grid-kpi .kpi:nth-child(4){animation-delay:.16s}.grid-kpi .kpi:nth-child(5){animation-delay:.2s}.grid-kpi .kpi:nth-child(6){animation-delay:.24s}.grid-kpi .kpi:nth-child(7){animation-delay:.28s}.grid-kpi .kpi:nth-child(8){animation-delay:.32s}.nav-btn{transition:background .15s,color .15s,transform .1s}.nav-btn:hover:not(.active){background:#f1f5f2;transform:translate(3px)}.btn{transition:background .15s,border-color .15s,box-shadow .15s,transform .12s}.btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 14px #0000001a}.btn.primary:hover:not(:disabled){background:linear-gradient(135deg,#15803d,#14532d)}.btn:active:not(:disabled){transform:translateY(0)}.input,.select{transition:border-color .15s,box-shadow .15s}.bar-fill{transform-origin:0;animation:.75s cubic-bezier(.16,1,.3,1) both barGrow}.hour-fill{transform-origin:0;animation:.7s cubic-bezier(.16,1,.3,1) both barGrow}tbody tr td{transition:background .12s}.pill{transition:transform .15s,box-shadow .15s}.pill:hover{transform:scale(1.06);box-shadow:0 2px 8px #0000001a}.chart-tooltip{animation:.1s fadeIn}.chart-loading{background:linear-gradient(90deg,#fafcfb 25%,#f1f6f2 50%,#fafcfb 75%) 0 0/200% 100%;animation:1.4s infinite shimmer,.2s fadeIn}.modal-backdrop{z-index:2000;background:#0f172a6b;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.modal-card{border:1px solid var(--line);background:#fff;border-radius:22px;width:min(440px,100%);padding:22px;animation:.18s both fadeSlideUp;box-shadow:0 24px 70px #0f172a38}.modal-card h3{color:var(--text);margin:0 0 10px;font-size:20px;font-weight:700}.modal-card p{color:#475569;white-space:pre-wrap;margin:0;font-size:14px;line-height:1.6}.modal-actions{justify-content:flex-end;gap:10px;margin-top:18px;display:flex}.customer-history{white-space:normal;gap:6px;min-width:280px;max-width:420px;display:grid}.customer-history-item{background:#fbfdfb;border:1px solid #e5eee7;border-radius:12px;gap:2px;padding:7px 9px;display:grid}.customer-history-item b{color:#172033;font-size:12px;font-weight:650}.customer-history-item span{color:#64748b;font-size:12px;line-height:1.35}.customer-history-more{color:#15803d;padding-left:4px;font-size:12px;font-weight:600}.customer-table{min-width:940px}.customer-toolbar{grid-template-columns:minmax(260px,1fr) auto auto auto;align-items:end;gap:12px;margin-top:12px;display:grid}.customer-page{gap:16px;display:grid}.customer-search-card{margin-bottom:0!important}.customer-search-row{grid-template-columns:minmax(280px,1fr) auto auto auto;align-items:end;gap:12px;display:grid}.customer-search-bottom{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:12px;margin-top:14px;display:flex}.customer-stat-grid{grid-template-columns:repeat(6,minmax(0,1fr));align-items:stretch;gap:14px;display:grid}.customer-stat-card{flex-direction:column;min-height:124px;display:flex;margin-bottom:0!important;padding:16px!important}.customer-stat-card:after{display:none}.customer-stat-title{color:var(--muted);align-items:flex-end;min-height:2.65em;margin:0 0 8px;font-size:13px;font-weight:500;line-height:1.35;display:flex}.customer-stat-value{letter-spacing:-.5px;flex:1;align-items:center;margin:0;font-size:26px;font-weight:650;line-height:1.1;display:flex}.customer-stat-note{color:var(--muted);align-items:flex-start;min-height:2.5em;margin:0;font-size:12px;line-height:1.35;display:flex}.customer-layout{grid-template-columns:minmax(0,1fr) 390px;align-items:start;gap:16px;display:grid}.customer-layout.detail-closed{grid-template-columns:1fr}.customer-table-card{overflow:hidden;padding:0!important}.customer-section-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:12px;padding:16px 18px;display:flex}.customer-table-wrap{max-height:720px;overflow:auto}.customer-matrix-table{border-collapse:separate;border-spacing:0;min-width:1500px}.customer-matrix-table th,.customer-matrix-table td{text-align:left;vertical-align:middle;white-space:nowrap;border-bottom:1px solid #edf2ea;border-right:1px solid #edf2ea;padding:12px;font-size:13px}.customer-matrix-table th{z-index:4;color:#15803d;background:#f6faf7;font-weight:650;position:sticky;top:0}.customer-matrix-table th:first-child,.customer-matrix-table td:first-child{z-index:3;background:#fff;border-right:1px solid #dbe7d8;position:sticky;left:0}.customer-matrix-table th:first-child{z-index:5;background:#f6faf7}.customer-matrix-table tbody tr:hover td,.customer-matrix-table tbody tr:hover td:first-child{background:#fbfdfb}.customer-phone{letter-spacing:.2px;font-size:14px;font-weight:650}.customer-count{text-align:center;font-size:15px;font-weight:650}.customer-month-cell{white-space:normal;min-width:125px}.customer-month-box{cursor:pointer;text-align:left;background:#fbfdfb;border:1px solid #e1eadf;border-radius:14px;width:100%;min-height:82px;padding:10px;font-family:inherit;transition:border-color .15s,background .15s,box-shadow .15s}.customer-month-box:hover,.customer-month-box.active{border-color:var(--green);background:var(--greenSoft);box-shadow:0 8px 18px #16a34a1f}.customer-month-main{color:var(--text);margin-bottom:7px;font-size:13px;font-weight:650}.customer-month-sub{color:var(--muted);font-size:12px;line-height:1.45}.customer-month-empty{color:#b0b8ae;text-align:center;padding:24px 0;font-size:13px}.customer-detail-panel{background:var(--panel);border:1px solid var(--line);max-height:calc(100vh - 32px);box-shadow:var(--shadow);border-radius:22px;position:sticky;top:16px;overflow:auto}.customer-detail-close{width:32px;height:32px;color:var(--muted);cursor:pointer;background:#fff;border:1px solid #d8e3d6;border-radius:999px;justify-content:center;align-items:center;padding:0;font-size:16px;font-weight:650;transition:background .15s,color .15s;display:inline-flex}.customer-detail-close:hover{color:var(--text);background:#f6faf5}.customer-detail-body{padding:18px}.customer-detail-phone{letter-spacing:.2px;margin-bottom:6px;font-size:23px;font-weight:650}.customer-detail-month{color:var(--muted);margin-bottom:16px;font-size:15px;line-height:1.6}.customer-info-grid{gap:10px;margin-bottom:18px;display:grid}.customer-info-box{background:#f8fbf7;border:1px solid #e3ece0;border-radius:14px;padding:12px}.customer-info-label{color:var(--muted);margin-bottom:5px;font-size:12px}.customer-info-value{white-space:normal;font-weight:650;line-height:1.45}.customer-timeline{gap:12px;display:grid}.customer-timeline-item{border-left:3px solid var(--green);background:#fbfdfb;border-top:1px solid #e5eee2;border-bottom:1px solid #e5eee2;border-right:1px solid #e5eee2;border-radius:0 14px 14px 0;padding:12px 12px 12px 14px}.customer-timeline-title{margin-bottom:6px;font-size:16px;font-weight:650}.customer-timeline-meta{color:var(--muted);margin-bottom:8px;font-size:12px;line-height:1.45}.customer-timeline-result{flex-wrap:wrap;gap:6px;display:flex}@media (max-width:1300px){.customer-stat-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.customer-layout{grid-template-columns:1fr}.customer-detail-panel{max-height:none;position:static}}@media (max-width:900px){.customer-search-row{grid-template-columns:1fr}.customer-search-bottom{justify-content:flex-start}}@media (max-width:760px){.customer-stat-grid{grid-template-columns:1fr}}.sidebar{z-index:40;flex-shrink:0;transition:width .2s,padding .2s,transform .2s}.main{z-index:1;flex:1;min-width:0;transition:padding .2s;position:relative}.sidebar-toggle{z-index:1100;cursor:pointer;background:#fff;border:1px solid #cbd8ce;border-radius:13px;place-content:center;gap:4px;width:42px;height:42px;display:grid;position:fixed;top:14px;left:14px;box-shadow:0 8px 22px #0f172a14}.sidebar-toggle span{background:#172033;border-radius:99px;width:18px;height:2px;display:block}.sidebar-backdrop{display:none}@media (max-width:700px){.app{width:100%;min-height:100vh;display:block}.sidebar-toggle{top:12px;left:12px}.sidebar-backdrop{z-index:998;cursor:pointer;background:#0f172a61;border:0;display:block;position:fixed;inset:0}.sidebar{z-index:999;border-right:1px solid var(--line);border-bottom:0;width:min(300px,86vw);height:100vh;padding:68px 12px 14px;position:fixed;inset:0 auto 0 0;overflow-y:auto;transform:translate(-100%);box-shadow:18px 0 48px #0f172a2e}.app.sidebar-open .sidebar{transform:translate(0)}.app.sidebar-closed .sidebar{border-right:1px solid var(--line);width:min(300px,86vw);padding:68px 12px 14px;transform:translate(-100%)}.app.sidebar-closed .sidebar>*{opacity:1;pointer-events:auto}.app.sidebar-closed .sidebar-backdrop{display:none}.brand{margin-bottom:14px;padding-left:0}.nav-label{margin:12px 4px 8px}.nav-btn{width:100%;padding:11px 12px}.main{width:100%;max-width:none;min-height:auto;padding:66px 12px 12px;overflow-x:visible}.hero{border-radius:22px;padding:16px;display:block}.hero .btn{margin-top:14px}.alert{margin-bottom:14px}.grid-kpi,.grid-2,.customer-toolbar{grid-template-columns:1fr}}.grid-kpi{align-items:stretch}.kpi{grid-template-rows:44px auto 1fr;align-content:start;height:100%;min-height:174px;padding:20px 18px;display:grid}.kpi .label{align-items:flex-start;min-height:40px;margin-bottom:0;line-height:1.25}.kpi .label .kpi-icon{margin-top:0}.kpi .value{white-space:nowrap;align-self:end;min-height:36px;margin:8px 0 6px;font-size:30px;line-height:1.1}.kpi .desc{min-height:42px;line-height:1.45}@media (max-width:700px){.kpi{grid-template-rows:auto auto auto;min-height:142px}.kpi .label,.kpi .desc{min-height:0}.kpi .value{min-height:0;font-size:26px}}.sidebar{flex-direction:column;display:flex}.sidebar-head{align-items:center;gap:12px;margin-bottom:26px;display:flex}.sidebar-head .brand{flex:auto;min-width:0;margin-bottom:0}.sidebar-head .brand-text{min-width:0}.sidebar-toggle{z-index:1;box-shadow:none;flex:0 0 42px;position:relative;top:auto;left:auto}.app.sidebar-open .sidebar-toggle{left:auto}.sidebar>.brand{padding-left:0}.sidebar-version{color:#64748b;border-top:1px solid #edf1ee;margin-top:auto;padding:14px 10px 0;font-size:12px;line-height:1.5}.sidebar-version div{color:#172033;font-weight:650}.sidebar-version span{display:block}.app.sidebar-closed .sidebar{border-right:1px solid var(--line);flex-shrink:0;width:58px;min-width:58px;padding:16px 8px;overflow:visible}.app.sidebar-closed .sidebar>*{opacity:1;pointer-events:auto}.app.sidebar-closed .sidebar-head{justify-content:center;margin-bottom:18px}.app.sidebar-closed .brand,.app.sidebar-closed .nav-label,.app.sidebar-closed .nav-text,.app.sidebar-closed .sidebar-version{display:none}.app.sidebar-closed .nav-btn{cursor:pointer;justify-content:center;width:42px;height:42px;margin:0 auto 8px;padding:0;position:relative;overflow:visible}.app.sidebar-closed .nav-btn[data-tooltip]:after,.app.sidebar-closed .sidebar-toggle[data-tooltip]:after{content:attr(data-tooltip);color:#fff;white-space:nowrap;opacity:0;visibility:hidden;pointer-events:none;z-index:1200;background:#172033;border-radius:10px;padding:8px 12px;font-size:13px;font-weight:500;line-height:1.3;transition:opacity .15s,visibility .15s;position:absolute;top:50%;left:calc(100% + 12px);transform:translateY(-50%);box-shadow:0 8px 24px #1020332e}.app.sidebar-closed .nav-btn[data-tooltip]:before,.app.sidebar-closed .sidebar-toggle[data-tooltip]:before{content:"";opacity:0;visibility:hidden;pointer-events:none;z-index:1200;border:6px solid #0000;border-right-color:#172033;transition:opacity .15s,visibility .15s;position:absolute;top:50%;left:calc(100% + 6px);transform:translateY(-50%)}.app.sidebar-closed .nav-btn[data-tooltip]:hover:after,.app.sidebar-closed .nav-btn[data-tooltip]:hover:before,.app.sidebar-closed .nav-btn[data-tooltip]:focus-visible:after,.app.sidebar-closed .nav-btn[data-tooltip]:focus-visible:before,.app.sidebar-closed .sidebar-toggle[data-tooltip]:hover:after,.app.sidebar-closed .sidebar-toggle[data-tooltip]:hover:before,.app.sidebar-closed .sidebar-toggle[data-tooltip]:focus-visible:after,.app.sidebar-closed .sidebar-toggle[data-tooltip]:focus-visible:before{opacity:1;visibility:visible}.app.sidebar-closed .sidebar-toggle{cursor:pointer;position:relative;overflow:visible}.app.sidebar-closed .main{max-width:1760px;margin-left:0;padding-left:26px}.app.sidebar-closed .hero{max-width:100%;margin-left:0}@media (max-width:700px){.sidebar-head{margin-bottom:14px}.app.sidebar-open .sidebar{padding-top:14px}}.sidebar-version{flex-shrink:0;margin-top:auto}@media (max-width:700px){.app.sidebar-open .sidebar{flex-direction:column;height:100vh;min-height:100vh;display:flex}.sidebar-version{padding-bottom:8px}}.overview-page{gap:16px;min-width:0;display:grid}.overview-kpi-top{grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);align-items:stretch;gap:20px;display:grid}.overview-panel{flex-direction:column;gap:12px;min-width:0;height:100%;display:flex}.overview-panel .overview-data-kpi,.overview-panel .overview-campaign-kpi{flex:1;min-height:0}.overview-section-title{color:var(--text);margin:0 0 2px;font-size:20px;font-weight:700;line-height:1.3}.overview-data-kpi{flex:1;grid-template-columns:repeat(4,minmax(0,1fr));align-items:stretch;gap:12px;width:100%;display:grid}.overview-data-kpi>.kpi{min-width:0;height:100%;min-height:148px;padding:16px 14px}.overview-campaign-kpi{flex:1;grid-template-columns:repeat(6,minmax(0,1fr));align-items:stretch;gap:12px;width:100%;display:grid}.overview-campaign-row{display:contents}.overview-campaign-row--2>.kpi{grid-column:span 3}.overview-campaign-row--3>.kpi{grid-column:span 2}.overview-campaign-kpi .kpi{min-width:0;height:100%;min-height:148px;padding:16px 14px}.overview-charts-donuts{grid-template-columns:minmax(0,.42fr) minmax(520px,.58fr);gap:16px;min-width:0;margin-bottom:0;display:grid}.overview-charts-bottom{grid-template-columns:minmax(0,.6fr) minmax(0,.4fr);align-items:stretch;gap:16px;min-width:0;margin-bottom:0;display:grid}.overview-charts-donuts .card,.overview-charts-donuts .chart-card,.overview-charts-bottom .chart-card{margin-bottom:0}@media (max-width:1280px){.overview-kpi-top,.overview-charts-donuts,.overview-charts-bottom{grid-template-columns:1fr}.overview-data-kpi,.overview-campaign-kpi{grid-template-columns:repeat(2,minmax(0,1fr))}.overview-campaign-row--2>.kpi,.overview-campaign-row--3>.kpi{grid-column:span 1}.overview-campaign-row--3>.kpi:last-child{grid-column:1/-1}}@media (max-width:900px){.overview-campaign-kpi{grid-template-columns:1fr}.overview-campaign-row--2>.kpi,.overview-campaign-row--3>.kpi{grid-column:1}}@media (max-width:700px){.overview-data-kpi{grid-template-columns:1fr}.overview-data-kpi>.kpi,.overview-campaign-kpi>.kpi{min-height:132px}}.overview-page{gap:18px}.overview-filter-card{border-radius:6px;margin-bottom:0;padding:14px 16px;box-shadow:0 2px 8px #0f172a0f}.overview-date-filter{flex-wrap:wrap;align-items:flex-end;gap:12px;display:flex}.overview-date-filter .field{flex:160px;min-width:0;max-width:220px}.overview-date-filter .btn{flex:none;min-width:88px}.overview-kpi-top{grid-template-columns:minmax(0,1.15fr) minmax(0,1fr)}.overview-section-title{letter-spacing:0;margin-bottom:6px;font-size:28px;font-weight:800;line-height:1.15}.overview-data-kpi,.overview-campaign-kpi{gap:12px}.overview-data-kpi{grid-auto-rows:1fr}.overview-charts-donuts{grid-template-columns:minmax(420px,.4fr) minmax(560px,.6fr);gap:20px}.overview-charts-bottom{grid-template-columns:minmax(560px,.6fr) minmax(420px,.4fr);align-items:stretch;gap:20px}.overview-charts-donuts .card,.overview-charts-bottom .chart-card{border-radius:6px;box-shadow:0 2px 8px #0f172a0f}.overview-charts-donuts .card{height:100%;min-height:360px;padding:16px 18px}.overview-charts-donuts .card-title,.overview-charts-bottom .chart-title{font-size:14px;line-height:1.3}.overview-charts-donuts .card-sub,.overview-charts-bottom .chart-sub{margin-bottom:8px;font-size:12px}.overview-charts-donuts .legend-item{gap:8px;padding-bottom:7px;font-size:12px}.overview-charts-bottom .chart-wrap,.overview-charts-donuts .chart-wrap{border-radius:4px}.overview-charts-bottom .chart-card--campaign-day,.overview-charts-bottom .chart-card--replay{flex-direction:column;height:100%;min-height:420px;padding:18px 20px 14px;display:flex}.overview-charts-bottom .chart-card--campaign-day .chart-wrap{flex-direction:column;flex:1;min-height:0;display:flex}.overview-charts-bottom .chart-card--replay .replay-compare{flex-direction:column;flex:1;justify-content:center;display:flex}.overview-charts-bottom .chart-card--campaign-day .chart-wrap,.overview-charts-bottom .chart-card--replay .chart-wrap{background:#fff;border:0;padding:0;overflow:visible}.overview-charts-bottom .chart-card--campaign-day .chart-title,.overview-charts-bottom .chart-card--replay .chart-title{color:#1f2937;margin-bottom:6px;font-size:15px}.overview-charts-bottom .chart-card--campaign-day .chart-sub,.overview-charts-bottom .chart-card--replay .chart-sub{color:#7b8494;margin-bottom:14px;font-size:12px;font-weight:600}.chart-svg--campaign-day{height:274px}.chart-svg--replay{height:276px}.chart-legend--bottom{color:#4b5563;justify-content:center;gap:14px;margin:6px 0 0;font-size:12px;font-weight:600}.chart-legend-bar{border-radius:3px;width:22px;height:14px;display:inline-block}.chart-legend-bar--soft-blue{background:#dbeafe}.chart-legend-line{border-radius:999px;width:18px;height:18px;display:inline-block;position:relative}@media (max-width:1280px){.overview-kpi-top,.overview-charts-donuts,.overview-charts-bottom{grid-template-columns:1fr}}@media (max-width:700px){.overview-section-title{font-size:22px}.overview-page .kpi{height:auto;min-height:86px}.overview-charts-donuts .donut-layout{grid-template-columns:1fr}.donut-wire-layout{grid-template-columns:1fr;padding-bottom:46px}.legend--wire{justify-self:center}.donut-highlight{white-space:normal;bottom:12px;right:12px}.overview-date-filter{grid-template-columns:1fr}}.overview-filter-card{box-shadow:var(--shadow);border-radius:22px;padding:18px}.overview-section-title{margin:0 0 2px;font-size:20px;font-weight:700;line-height:1.3}.overview-data-kpi>.kpi,.overview-campaign-kpi .kpi,.overview-page .kpi{text-align:left;border-color:var(--line);height:100%;min-height:148px;box-shadow:var(--shadow);background:var(--panel);border-radius:22px;flex-direction:column;align-items:flex-start;padding:16px 14px;display:flex;overflow:hidden}.overview-page .kpi:after{display:block}.kpi-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:inline-flex}.kpi-icon--blue{color:#2563eb;background:#eff6ff}.kpi-icon--green{color:#15803d;background:#ecfdf3}.kpi-icon--orange{color:#ea580c;background:#fff7ed}.kpi-icon--red{color:#dc2626;background:#fef2f2}.kpi-icon--purple{color:#7c3aed;background:#f5f3ff}.overview-page .kpi .kpi-label-text{flex:1;min-width:0}.overview-page .kpi .desc{display:block}.overview-page .kpi .label{width:100%;min-height:2.7em;color:var(--text);text-align:left;flex-shrink:0;justify-content:flex-start;align-items:flex-start;gap:10px;margin:0;font-size:13px;font-weight:500;line-height:1.35;display:flex}.overview-page .kpi .label>span:last-child{word-break:break-word;display:block}.overview-page .kpi .value{width:100%;min-height:1.2em;color:var(--text);white-space:nowrap;text-overflow:ellipsis;text-align:left;flex-shrink:0;align-self:flex-start;margin:8px 0 0;font-size:clamp(20px,2vw,26px);font-weight:650;line-height:1.2;overflow:hidden}.overview-campaign-kpi .kpi .value{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.overview-page .kpi .desc{width:100%;min-height:0;color:var(--muted);text-align:left;flex-shrink:0;align-self:flex-start;margin-top:6px;padding-top:0;font-size:13px;line-height:1.45}.overview-charts-donuts .card,.overview-charts-bottom .chart-card{box-shadow:var(--shadow);border-radius:22px}.overview-charts-donuts .card{min-height:auto;padding:18px}.overview-charts-donuts .card-title,.overview-charts-bottom .chart-title{font-size:18px;font-weight:700;line-height:1.2}.overview-charts-bottom .chart-title{font-size:20px}.overview-charts-donuts .card-sub,.overview-charts-bottom .chart-sub{margin-bottom:12px;font-size:14px;line-height:1.5}.overview-charts-donuts .donut-layout{grid-template-columns:300px 1fr;gap:20px;min-height:310px}.overview-charts-donuts .donut-wrap,.overview-charts-donuts .donut{width:280px;height:280px}.overview-charts-donuts .donut:after{inset:54px}.overview-charts-donuts .donut-center .big{font-size:34px}.overview-charts-donuts .donut-center .small{font-size:12px}.overview-charts-donuts .legend{gap:10px}.overview-charts-donuts .legend-item{border-bottom:1px dashed #e2e8f0;grid-template-columns:1fr auto;gap:14px;padding-bottom:10px;font-size:14px}.overview-charts-donuts .insight{border-radius:16px;margin-top:13px;font-size:14px;line-height:1.6}.overview-charts-bottom .chart-card{padding:18px 20px 16px}.overview-charts-bottom .chart-wrap,.overview-charts-donuts .chart-wrap{background:#fcfdfc;border:1px solid #dfe8dc;border-radius:20px;padding:10px 14px 6px;overflow:hidden}.overview-charts-bottom .chart-svg{min-height:330px}@media (max-width:1200px){.overview-charts-donuts .donut-layout{grid-template-columns:1fr}}@media (max-width:700px){.overview-section-title{font-size:20px}.overview-data-kpi>.kpi,.overview-campaign-kpi .kpi,.overview-page .kpi{height:100%;min-height:132px}.overview-page .kpi .label{min-height:2.5em}.overview-page .kpi .desc{min-height:2.6em}.overview-charts-donuts .donut-wrap,.overview-charts-donuts .donut{width:220px;height:220px}.overview-charts-donuts .donut:after{inset:42px}}.donut-card{position:relative;overflow:hidden}.donut-wire-layout{grid-template-columns:minmax(360px,1fr) minmax(145px,180px);align-items:center;gap:6px;min-height:390px;display:grid;position:relative}.donut-card--connection-wire .donut-wrap,.donut-card--connection-wire .donut,.donut-card--connection-wire .donut-svg{width:360px;height:360px}.donut-svg{display:block;overflow:visible}.donut-svg path,.donut-slice{cursor:pointer;transform-box:view-box;transition:transform .18s,filter .18s,stroke-width .18s}.donut-svg path:hover,.donut-slice.is-hovered{filter:drop-shadow(0 10px 16px #0f172a38)brightness(1.04);transform:scale(1.055)}.legend--wire{align-self:center;gap:11px}.legend--wire .legend-item{color:#4b5563;border-bottom:0;padding-bottom:0;font-size:13px;display:block}.legend-swatch{border-radius:3px;flex:none;width:18px;height:12px;display:inline-block}.legend--wire .legend-left{gap:8px}.donut-highlight{color:#6b7280;white-space:nowrap;background:#fff;border:1px solid;border-radius:4px;max-width:calc(100% - 36px);padding:10px 12px;font-size:12px;font-weight:600;line-height:1.35;position:absolute;bottom:22px;right:22px;box-shadow:0 8px 20px #0f172a1f}.donut-survey-layout{place-items:center;max-width:620px;min-height:360px;margin:0 auto;display:grid;position:relative}.donut-card--survey-wire .donut-wrap,.donut-card--survey-wire .donut,.donut-card--survey-wire .donut-svg{width:330px;height:330px}.survey-callouts{pointer-events:auto;position:absolute;inset:0}.survey-callout{color:#4b5563;white-space:nowrap;cursor:default;font-size:12px;font-weight:650;line-height:1.2;position:absolute}.survey-callout b{font-weight:650;display:block}.survey-callout--1{top:48%;right:2%}.survey-callout--2{top:49%;left:3%}.survey-callout--3{top:28%;left:12%}.survey-callout--4{top:12%;left:34%}.survey-callout--5{top:23%;right:14%}.legend--survey-bottom{flex-wrap:wrap;justify-content:center;gap:14px;margin-top:-6px;display:flex}.legend--survey-bottom .legend-bottom-item{color:#4b5563;align-items:center;gap:7px;font-size:12px;font-weight:600;display:inline-flex}.donut-tooltip{z-index:40;color:#172033;pointer-events:none;background:#fff;border:1px solid #d9e1ef;border-radius:12px;min-width:138px;max-width:160px;padding:9px 10px;font-size:13px;line-height:1.4;position:absolute;transform:translateY(-100%);box-shadow:0 10px 30px #1020331f}.donut-tooltip-title{margin-bottom:3px;font-weight:700}@media (max-width:700px){.donut-wire-layout{grid-template-columns:1fr;padding-bottom:48px}.donut-card--connection-wire .donut-wrap,.donut-card--connection-wire .donut,.donut-card--connection-wire .donut-svg,.donut-card--survey-wire .donut-wrap,.donut-card--survey-wire .donut,.donut-card--survey-wire .donut-svg{width:240px;height:240px}.legend--wire{justify-self:center}.donut-highlight{white-space:normal;bottom:12px;right:12px}.survey-callout{display:none}}.echarts-donut{width:100%;min-height:390px}.echarts-donut--survey,.echarts-donut--connection{height:390px;min-height:390px}.donut-legend-below{border-top:1px solid #eef2f7;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 16px;margin-top:4px;padding-top:12px;display:grid}.donut-legend-below-item{color:#475569;grid-template-columns:auto 1fr auto;align-items:center;gap:8px;font-size:13px;display:grid}.donut-legend-below-label{font-weight:500;line-height:1.3}.donut-legend-below-value{color:#172033;white-space:nowrap;font-weight:700}.donut-legend-below-pct{color:#64748b;font-size:12px;font-weight:500}.chart-note,.insight{color:#475569;background:#fafcfb;border:1px dashed #d7e6db;border-radius:14px;margin-top:12px;margin-bottom:0;padding:12px 14px;font-family:inherit;font-size:13px;font-weight:400;line-height:1.55}.chart-title,.card-title{color:var(--text);font-family:inherit;font-weight:700}.chart-sub,.card-sub{color:var(--muted);font-family:inherit;font-size:13px;font-weight:500;line-height:1.5}.chart-legend,.chart-legend-item,.donut-legend-below,.donut-legend-below-label,.donut-legend-below-value,.replay-compare-label,.replay-compare-value,.replay-compare-tag,.chart-tooltip,.chart-tooltip-title,.chart-tooltip-label,.chart-tooltip-value{font-family:inherit}.overview-charts-donuts{align-items:stretch}.overview-charts-donuts .card,.donut-card{flex-direction:column;height:100%;display:flex}.donut-card .echarts-donut,.donut-card .echarts-donut--survey{flex:1;min-height:390px}.echarts-bar{width:100%;min-height:276px}.replay-compare{flex-direction:column;gap:18px;margin-top:4px;display:flex}.replay-compare-row{grid-template-columns:minmax(140px,168px) 1fr;align-items:start;gap:12px 16px;display:grid}.replay-compare-label{color:#475569;padding-top:6px;font-size:12px;font-weight:700}.replay-compare-bars{flex-direction:column;gap:8px;display:flex}.replay-compare-barline{grid-template-columns:52px 1fr auto;align-items:center;gap:10px;display:grid}.replay-compare-tag{font-size:11px;font-weight:700}.replay-compare-track{background:#f1f5f9;border-radius:999px;height:14px;overflow:hidden}.replay-compare-fill{border-radius:999px;min-width:4px;height:100%;transition:width .35s}.replay-compare-value{color:#334155;text-align:right;min-width:52px;font-size:12px;font-weight:700}.replay-compare-legend{border-top:1px solid #eef2f7;margin-top:12px;margin-bottom:0;padding-top:10px}.chart-wrap--scroll-x{-webkit-overflow-scrolling:touch;overflow:auto hidden}.chart-wrap--scroll-x .chart-svg--campaign-day{min-width:100%;height:274px;display:block}.echarts-bar--replay{height:auto;min-height:0}.pill.purple{color:#6d28d9;background:#f1e8ff}.table-summary-strip{flex-wrap:wrap;gap:12px;margin:0 0 14px;display:flex}.table-summary-item{background:#fbfdfb;border:1px solid #dfe7e1;border-radius:16px;gap:4px;min-width:190px;padding:12px 14px;display:grid}.table-summary-item span{color:var(--muted);font-size:13px;line-height:1.35}.table-summary-item b{color:var(--text);font-size:22px;font-weight:650;line-height:1.1}.overview-page .kpi{grid-template-rows:74px 48px minmax(0,1fr);align-content:start;padding:18px;display:grid}.overview-page .kpi .label{grid-template-columns:44px minmax(0,1fr);align-items:start;gap:12px;width:100%;height:74px;min-height:0;margin:0;display:grid}.overview-page .kpi .kpi-label-text{overflow-wrap:anywhere;min-width:0;line-height:1.32}.overview-page .kpi .kpi-icon{border-radius:14px;width:44px;height:44px}.overview-page .kpi .value{letter-spacing:0;align-self:center;width:100%;min-height:0;margin:0;font-size:clamp(26px,1.9vw,36px);line-height:1.05}.overview-campaign-row--3>.kpi .value{font-size:clamp(24px,1.65vw,32px)}.overview-page .kpi .desc{width:100%;margin:4px 0 0;line-height:1.45}.overview-summary-layout{grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:stretch;gap:18px;display:grid}.overview-top-kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;display:grid}.overview-top-kpi-card{background:#fff;border:1px solid #edf1f5;border-radius:14px;grid-template-columns:48px minmax(0,1fr);align-items:stretch;gap:16px;min-width:0;min-height:126px;padding:22px 24px;display:grid;position:relative;box-shadow:0 8px 22px #0f172a09}.overview-top-kpi-card .kpi-icon{border-radius:14px;width:42px;height:42px}.overview-top-kpi-card .kpi-icon svg{width:20px;height:20px}.overview-top-kpi-body{grid-template-rows:minmax(18px,auto) 38px minmax(32px,auto);align-content:start;min-width:0;display:grid}.overview-top-kpi-label{color:var(--text);white-space:normal;overflow-wrap:anywhere;margin-bottom:0;font-size:13px;font-weight:750;line-height:1.3}.overview-top-kpi-value{color:#0f172a;letter-spacing:-.02em;align-self:center;margin-bottom:0;font-size:clamp(26px,1.8vw,34px);font-weight:800;line-height:1}.overview-top-kpi-value--green{color:#15803d}.overview-top-kpi-value--red{color:#dc2626}.overview-top-kpi-value--orange{color:#f59e0b}.overview-top-kpi-value--purple{color:#7c3aed}.overview-top-kpi-desc{color:#64748b;font-size:12px;font-weight:450;line-height:1.55}.overview-top-kpi-note{border-radius:999px;padding:6px 10px;font-size:11px;font-weight:700;position:absolute;bottom:18px;right:18px}.overview-summary-section{border:1px solid var(--line);box-shadow:var(--shadow);background:#fff;border-radius:14px;flex-direction:column;padding:18px;display:flex}.overview-summary-head{align-items:center;gap:10px;margin-bottom:18px;display:flex}.overview-summary-head h2{color:var(--text);margin:0;font-size:18px;font-weight:750;line-height:1.2}.overview-summary-chip{color:#64748b;white-space:nowrap;background:#f3f5fb;border-radius:999px;align-items:center;gap:6px;margin-left:10px;padding:8px 14px;font-size:13px;font-weight:650;display:inline-flex}.overview-summary-grid{flex:1;grid-template-columns:repeat(4,minmax(0,1fr));align-content:stretch;gap:8px;display:grid}.overview-summary-section--customer .overview-stat-card,.overview-summary-section--customer .overview-stat-card--wide,.overview-summary-section--campaign .overview-stat-card{grid-column:span 1}.overview-stat-card{background:#fff;border:1px solid #e3e9e2;border-radius:12px;grid-template-rows:minmax(56px,auto) auto 1px auto minmax(0,auto);align-content:start;gap:9px;min-width:0;padding:14px;display:grid;box-shadow:0 5px 14px #0f172a09}.overview-stat-head{grid-template-columns:28px minmax(0,1fr);align-items:start;gap:8px;display:grid}.overview-stat-card .kpi-icon{border-radius:9px;width:28px;height:28px}.overview-stat-card .kpi-icon svg{width:15px;height:15px}.overview-stat-label{color:var(--text);align-items:flex-start;min-height:2.6em;font-size:12px;font-weight:650;line-height:1.35;display:flex}.overview-stat-value{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:clamp(20px,1.35vw,26px);font-weight:780;line-height:1.12;overflow:hidden}.overview-stat-value--green{color:#15803d}.overview-stat-value--red{color:#dc2626}.overview-stat-value--orange{color:#f59e0b}.overview-stat-value--purple{color:#7c3aed}.overview-stat-value--blue{color:#0f172a}.overview-stat-value--compound{white-space:normal;text-overflow:clip;overflow-wrap:anywhere;font-size:clamp(17px,1.05vw,22px);line-height:1.15;overflow:visible}.overview-stat-rule{background:#e5e7eb;width:100%;height:1px}.overview-stat-desc{color:#475569;font-size:11px;font-weight:450;line-height:1.45}.overview-stat-note{white-space:normal;text-overflow:clip;border-radius:999px;width:fit-content;max-width:100%;margin-top:1px;padding:6px 9px;font-size:10px;font-weight:700;line-height:1.25;overflow:visible}.overview-stat-note--green{color:#15803d;background:#ecfdf3}.overview-stat-note--red{color:#b91c1c;background:#fef2f2}.overview-rule-note{border:1px solid var(--line);box-shadow:var(--shadow);color:#64748b;background:#fff;border-radius:16px;flex-wrap:wrap;align-items:center;gap:9px;padding:14px 20px;font-size:14px;line-height:1.45;display:flex}.overview-rule-note b{color:var(--text)}@media (max-width:1400px){.overview-top-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.overview-summary-layout{grid-template-columns:1fr}}@media (max-width:1200px){.overview-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:900px){.overview-summary-head{flex-wrap:wrap;align-items:flex-start}.overview-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.overview-summary-chip{margin-left:0}.overview-summary-section--customer .overview-stat-card,.overview-summary-section--customer .overview-stat-card--wide,.overview-summary-section--campaign .overview-stat-card{grid-column:span 1}}@media (max-width:700px){.overview-top-kpi-grid{grid-template-columns:1fr}.overview-top-kpi-card{min-height:112px;padding:18px}.overview-top-kpi-body{grid-template-rows:auto auto auto;gap:6px}.overview-top-kpi-label{white-space:normal;line-height:1.35}.overview-summary-section{border-radius:20px;padding:16px}.overview-summary-head h2{font-size:20px}.overview-summary-grid{grid-template-columns:1fr}.overview-summary-section--customer .overview-stat-card,.overview-summary-section--customer .overview-stat-card--wide,.overview-summary-section--campaign .overview-stat-card{grid-column:1}.overview-stat-card{grid-template-rows:minmax(56px,auto) auto 1px auto minmax(0,auto)}.overview-stat-note{white-space:normal}.echarts-bar{min-height:260px}}.app{width:100%}.main,.app.sidebar-open .main,.app.sidebar-closed .main{flex:auto;width:100%;max-width:none}.hero,.overview-page,.overview-filter-card,.overview-summary-layout,.overview-charts-donuts,.overview-charts-bottom{width:100%;max-width:none}.donut-card--connection-wire .echarts-donut--connection{min-height:390px}@media (max-width:900px){.donut-card--connection-wire .echarts-donut--connection,.donut-card--survey-wire .echarts-donut--survey{min-height:360px}}@media (max-width:520px){.donut-card--connection-wire .echarts-donut--connection,.donut-card--survey-wire .echarts-donut--survey{min-height:330px}}.media-play-btn{color:#172033;min-height:32px;font:inherit;cursor:pointer;background:#fff;border:1px solid #cfe1d5;border-radius:999px;align-items:center;gap:7px;padding:0 11px;font-size:13px;font-weight:500;display:inline-flex}.media-play-btn:hover{background:#f6fbf7;border-color:#9fd1ac}.media-play-icon{border-top:6px solid #0000;border-bottom:6px solid #0000;border-left:9px solid #16a34a;width:0;height:0}.media-player-backdrop{z-index:80;background:#0f172a7a;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.media-player-dialog{background:#fff;border:1px solid #dfe7df;border-radius:22px;width:min(860px,100%);overflow:hidden;box-shadow:0 28px 80px #0f172a3d}.media-player-head{border-bottom:1px solid #edf1ee;justify-content:space-between;align-items:center;gap:16px;padding:14px 16px;display:flex}.media-player-close{color:#64748b;cursor:pointer;background:#fff;border:1px solid #d8e3da;border-radius:999px;width:34px;height:34px;font-size:24px;line-height:1}.media-player-video{background:#020617;width:100%;max-height:70vh;display:block}.media-player-audio{width:calc(100% - 32px);margin:22px 16px 24px;display:block}.media-player-link{color:#15803d;margin:22px 16px 24px;font-weight:600;display:inline-flex}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
@media (max-width:900px){.hero{flex-direction:column;align-items:stretch;gap:12px;display:flex}.hero>div{min-width:0}.hero .btn{width:100%;margin-top:0}.hero h1{font-size:22px}}@media (max-width:768px){.app.sidebar-closed .sidebar{pointer-events:none;box-shadow:none;border:none;width:min(300px,88vw)!important;padding:68px 12px 14px!important;transform:translate(-100%)!important}.app.sidebar-closed .sidebar-head,.app.sidebar-closed .sidebar>*{opacity:1}.app.sidebar-open .sidebar{pointer-events:auto;transform:translate(0)!important}.app.sidebar-closed .main,.app.sidebar-open .main{width:100%;max-width:none;margin-left:0!important;padding:64px 12px 16px!important}.overview-page{gap:14px}.overview-summary-layout,.overview-charts-donuts,.overview-charts-bottom{gap:14px;grid-template-columns:1fr!important}.overview-charts-donuts .card,.overview-charts-bottom .chart-card,.donut-card{min-width:0}.echarts-donut,.echarts-donut--survey{height:clamp(290px,76vw,340px);min-height:310px;width:100%!important}.echarts-donut--connection{height:clamp(290px,76vw,340px);min-height:310px}.donut-card{overflow:visible}.overview-charts-bottom .chart-wrap--scroll-x{margin:0 -4px}.replay-compare-row{grid-template-columns:1fr;gap:8px}.replay-compare-label{padding-top:0}.replay-compare-barline{grid-template-columns:48px 1fr minmax(52px,auto)}.card-title{font-size:18px;line-height:1.25}.card-sub,.overview-charts-donuts .card-sub{font-size:13px}.chart-legend{justify-content:flex-start}.table-wrap{-webkit-overflow-scrolling:touch}.customer-search-row{grid-template-columns:1fr!important}.customer-search-bottom{flex-direction:column;align-items:stretch}.customer-search-row .btn,.customer-search-bottom .btn{width:100%}.customer-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}.detail-filters,.grid-2{grid-template-columns:1fr!important}}@media (max-width:480px){.main{padding-left:10px!important;padding-right:10px!important}.overview-date-filter .field{flex:100%;max-width:none}.overview-date-filter .btn{flex:calc(50% - 6px)}.echarts-donut,.echarts-donut--survey{height:clamp(280px,82vw,320px);min-height:290px}.hero h1{font-size:18px}.chart-legend{flex-wrap:wrap;gap:8px 12px}.customer-stat-grid{grid-template-columns:1fr!important}}@media (min-width:769px) and (max-width:900px){.app.sidebar-closed .sidebar{pointer-events:auto;width:58px;padding:12px 8px!important;transform:translate(0)!important}.app.sidebar-closed .main{padding-left:74px!important}}
