:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#11243b;background:radial-gradient(circle at top left,rgba(69,182,195,.25),transparent 30%),linear-gradient(180deg,#f6efe4,#eef4fb);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5;font-weight:400}*{box-sizing:border-box}html,body,#root{height:100%;overflow:hidden}body{margin:0;min-width:320px;min-height:100dvh}button,input,select,textarea{font:inherit}input,select,textarea{caret-color:auto}button{border:0;border-radius:14px;padding:14px 20px;background:linear-gradient(135deg,#11243b,#1f5f78);color:#fff;font-weight:700;cursor:pointer;transition:transform .14s ease,box-shadow .14s ease}button:hover{transform:translateY(-1px);box-shadow:0 12px 30px #11243b2e}button:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.button-secondary{background:#dfe8f1;color:#11243b}.field{display:grid;gap:8px;font-weight:600}.field input,.field select,.field textarea{width:100%;padding:14px 16px;border-radius:14px;border:1px solid rgba(17,36,59,.12);background:#ffffffe6;color:#11243b}.field textarea{resize:vertical;min-height:92px}.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid rgba(69,182,195,.45);outline-offset:2px}.field-note{font-size:.76rem;line-height:1.4;color:#11243b9e}.field-note-error{color:#aa4729}.field-compact{max-width:220px}.action-row{display:flex;flex-wrap:wrap;gap:12px}.eyebrow{margin:0 0 10px;text-transform:uppercase;letter-spacing:.16em;font-size:.75rem;font-weight:700;color:#d1542d}.pill{padding:8px 12px;border-radius:999px;background:#d1542d1f;color:#aa4729;font-size:.82rem;font-weight:700}.pill-neutral{background:#11243b14;color:#11243b}.viewed-note{color:#111;font-weight:600}.logs-list{margin:10px 0 0;padding-left:18px}.logs-list li+li{margin-top:8px}code{padding:2px 6px;border-radius:6px;background:#11243b14}table{width:100%;border-collapse:collapse;min-width:640px}th,td{padding:16px 14px;text-align:left;border-bottom:1px solid rgba(17,36,59,.08)}th{font-size:.84rem;text-transform:uppercase;letter-spacing:.08em;color:#11243b94}tbody tr:hover{background:#45b6c30f}.app-shell{width:100%;height:100dvh;margin:0;padding:16px;display:grid;grid-template-rows:auto 1fr;gap:14px;overflow:hidden;caret-color:transparent}.dashboard-header{display:flex;align-items:flex-start;justify-content:flex-start;gap:28px;flex-wrap:nowrap;padding:16px 18px;border:1px solid rgba(17,36,59,.08);border-radius:24px;background:linear-gradient(180deg,#fffffff0,#ffffffe6),#ffffffdb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 24px 80px #11243b14}.dashboard-header h1,.table-heading h2{margin:0;letter-spacing:-.03em}.dashboard-header h1{font-size:clamp(1.15rem,1.7vw,1.55rem);white-space:nowrap}.table-heading h2{font-size:clamp(1.2rem,1.8vw,1.8rem)}.dashboard-header h1,.workspace-card__header,.eyebrow,.pill,.field>span,.time-selector__separator,.chart-hint,.clip-editor__heading strong,.clip-editor__meta,.clip-range-values,.workspace-empty,.table-selection strong,.table-selection p{-webkit-user-select:none;user-select:none;cursor:default}.video-crop-selection__label,.header-summary-button{-webkit-user-select:none;user-select:none}.header-query-form{flex:0 1 auto;display:grid;grid-template-columns:minmax(160px,210px) minmax(120px,180px) auto;align-items:end;gap:10px;min-width:0;margin-right:auto}.field-header{min-width:0;gap:6px}.field-header--streamer{align-self:stretch}.field-header span{padding-left:4px;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:#11243b9e}.header-query-form .field input,.header-query-form .field select{min-height:50px;padding:12px 16px;border-color:#11243b1a;background:#fffffff5;box-shadow:0 6px 16px #11243b0a}.header-query-form__actions{flex-wrap:nowrap;align-items:end;gap:0}.header-run-button{display:inline-flex;align-items:center;justify-content:center;width:50px;min-width:50px;min-height:50px;padding:0;border-radius:16px;box-shadow:0 12px 30px #11243b29}.header-run-button.is-running{background:linear-gradient(135deg,#d1542d,#b33d21)}.header-run-button__icon{display:block;color:currentColor}.header-run-button__icon.is-play{width:0;height:0;margin-left:4px;border-top:9px solid transparent;border-bottom:9px solid transparent;border-left:14px solid currentColor}.header-run-button__icon.is-stop{width:14px;height:14px;background:currentColor;border-radius:2px}.header-tiktok-button{min-height:50px;padding:12px 18px;border-radius:16px;white-space:nowrap;flex-shrink:0;margin-left:0;align-self:center;border:1px solid rgba(31,95,120,.14);box-shadow:0 12px 28px #1f5f781a}.header-tiktok-button.is-connect{background:linear-gradient(135deg,#11243b,#1f5f78);color:#fff}.header-tiktok-button.is-disconnect{background:linear-gradient(180deg,#eef4fa,#dde8f4);color:#11243b}.header-tiktok-button.is-unavailable{background:linear-gradient(180deg,#eef2f6,#e1e8ef);color:#11243bc2;box-shadow:none}.dashboard-layout{min-height:0;display:block;overflow:hidden}.dashboard-main{height:100%;min-height:0;display:flex;flex-direction:column;gap:12px;overflow:auto}.workflow-nav{display:flex;flex-wrap:wrap;gap:8px}.workflow-nav__step{padding:8px 12px;border-radius:999px;background:#dfe8f1;color:#11243b;box-shadow:none}.workflow-nav__step.is-active{background:linear-gradient(135deg,#11243b,#1f5f78);color:#fff}.workspace-card{border:1px solid rgba(17,36,59,.08);border-radius:24px;background:#ffffffdb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 24px 80px #11243b14;padding:18px;display:flex;flex-direction:column;gap:14px;min-height:0;overflow:visible}.workspace-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.workspace-card__header-note{margin:6px 0 0;color:#11243bad;font-size:.94rem}.workspace-card--chart .chart-wrap{flex:1 1 auto;min-height:340px;display:grid}.workspace-card--studio{align-content:start}.table-heading{display:flex;justify-content:space-between;gap:16px;align-items:center}.table-selection{margin-bottom:8px;padding:12px 14px;border-radius:16px;background:#f4f8fc;color:#11243bcc}.table-selection p{margin:6px 0 0}.workspace-empty{min-height:180px;display:grid;place-items:center;padding:22px;border-radius:18px;border:1px dashed rgba(17,36,59,.14);background:#f4f8fc;text-align:center;color:#11243bb3}.video-selection-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.video-selection-card{position:relative;padding:0;overflow:visible;background:#fffffff5;color:#11243b;border:1px solid rgba(17,36,59,.12);box-shadow:0 20px 40px #11243b1a;text-align:left}.video-selection-card.is-selected{border-color:#1f5f78;box-shadow:0 24px 44px #1f5f7838}.video-selection-card__preview{position:relative;overflow:visible}.video-selection-card__status-row{position:absolute;top:0;left:12px;z-index:2;display:flex;flex-wrap:wrap;gap:6px;transform:translateY(-42%)}.video-selection-card__status{padding:4px 8px;border-radius:999px;background:#11243bdb;color:#fff;font-size:.68rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;border:1px solid rgba(255,255,255,.72);box-shadow:0 8px 18px #11243b3d}.video-selection-card__status--clipped{background:#d1542deb}.video-selection-card__thumbnail{display:block;width:100%;aspect-ratio:16 / 9;object-fit:cover;background:#0e1824;border-radius:13px 13px 0 0}.video-selection-card__thumbnail--empty{display:grid;place-items:center;color:#ffffffd1}.video-selection-card__body{display:grid;gap:8px;padding:12px}.video-selection-card__streamer{font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:#11243b9e}.video-selection-card__title{line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.video-selection-card__meta{display:flex;justify-content:space-between;gap:12px;font-size:.76rem;color:#11243b9e}.chart-toolbar{display:flex;justify-content:space-between;align-items:end;flex-wrap:wrap;gap:12px}.time-selector{display:flex;align-items:end;flex-wrap:wrap;gap:10px}.field-time{min-width:96px}.time-selector__separator{padding-bottom:14px;font-size:1.4rem;font-weight:700;color:#11243ba6}@media (max-width: 1180px){.dashboard-main{grid-template-columns:1fr}}@media (max-width: 860px){.app-shell{padding:12px;gap:12px}.dashboard-header{flex-direction:column;padding:12px 14px;align-items:flex-start;gap:14px}.header-query-form{width:100%;margin-right:0;grid-template-columns:1fr;align-items:stretch}.header-query-form__actions{flex-wrap:wrap;gap:8px}.header-run-button{width:100%}.header-tiktok-button{width:100%;align-self:stretch}.dashboard-main{overflow:auto}.workflow-nav{width:100%}}@media (max-width: 640px){.chart-toolbar{justify-content:stretch}.time-selector{width:100%}.field-time{min-width:0;flex:1 1 120px}.time-selector button{width:100%}.field-compact{max-width:none}}.chart-wrap{border-radius:20px;background:#f4f8fc;padding:12px;min-height:340px}.plotly-chart{width:100%}.plotly-chart .js-plotly-plot,.plotly-chart .plotly,.plotly-chart .plotly .main-svg,.plotly-chart .plotly .barlayer .bars .point{cursor:pointer}.plotly-chart .plotly .main-svg text,.plotly-chart .rangeslider-container,.plotly-chart .rangeslider-container *{-webkit-user-select:none;user-select:none;cursor:inherit}.chart-hint{margin:4px 4px 0;color:#11243bb8;font-size:.88rem}.chart-empty{height:100%;min-height:0;display:grid;place-items:center;text-align:center;color:#11243bb3;padding:24px}.clip-studio{display:grid;gap:16px}.clip-editor{display:grid;gap:12px}.clip-editor+.clip-editor{padding-top:14px;border-top:1px solid rgba(17,36,59,.08)}.clip-editor p{margin:0}.clip-editor__heading{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.clip-editor__heading-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.clip-editor__icon-button{width:44px;height:44px;padding:0;display:grid;place-items:center}.clip-editor__icon-button svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}.clip-editor__meta{color:#11243bc7}.clip-editor__meta--compact{font-size:.94rem}.clip-editor__composition-field{max-width:320px}.clip-editor__status{margin:0;padding:10px 12px;border-radius:14px;background:#f4f8fc;color:#11243bcc}.clip-player{display:block;width:100%;max-width:100%;max-height:min(44dvh,420px);border-radius:14px;align-self:start}.clip-player--publish{max-height:min(52dvh,520px);border:1px solid rgba(17,36,59,.12);background:#0e1824}.clip-range{margin-top:4px}.clip-range--preview{margin-top:0}.clip-range-values{display:flex;justify-content:space-between;gap:12px;margin-bottom:10px;font-weight:600}.clip-range__input{display:block;width:100%;margin:0;accent-color:#11243b}.dual-range-slider{position:relative;height:28px;display:flex;align-items:center}.dual-range-slider__track,.dual-range-slider__range{position:absolute;left:0;right:0;height:6px;border-radius:999px}.dual-range-slider__track{background:#11243b24}.dual-range-slider__range{background:linear-gradient(135deg,#11243b,#1f5f78)}.dual-range-slider__input{position:absolute;left:0;width:100%;height:28px;margin:0;pointer-events:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:none}.dual-range-slider__input::-webkit-slider-thumb{pointer-events:auto;-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border:2px solid #11243b;border-radius:50%;background:#fff;box-shadow:0 4px 12px #11243b2e;cursor:pointer}.dual-range-slider__input::-moz-range-thumb{pointer-events:auto;width:18px;height:18px;border:2px solid #11243b;border-radius:50%;background:#fff;box-shadow:0 4px 12px #11243b2e;cursor:pointer}.dual-range-slider__input::-webkit-slider-runnable-track{background:transparent}.dual-range-slider__input::-moz-range-track{background:transparent}.clip-editor__hidden-video{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.stacked-preview-layout{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(260px,.8fr);gap:12px;align-items:start}.stacked-preview-layout.is-preview-only{grid-template-columns:minmax(0,1fr)}.stacked-preview-panel{display:grid;gap:8px;min-width:0}.stacked-preview-layout.is-preview-only .stacked-preview-panel{max-width:340px;width:100%;justify-self:center}.stacked-preview-panel__label{color:#11243bad;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.publish-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,.9fr);gap:14px;align-items:start}.publish-preview-panel,.publish-controls{display:grid;gap:10px;min-width:0}.video-crop-stage{position:relative;min-height:160px;display:grid;place-items:center;padding:12px;overflow:hidden;border-radius:18px;background:linear-gradient(135deg,#11243b0f,#1f5f781f),#dce6f1;border:1px solid rgba(17,36,59,.12)}.video-crop-stage:fullscreen{padding:24px;border:0;border-radius:0;background:#081018f5}.video-crop-stage__surface{position:relative;width:100%;max-width:min(100%,var(--video-crop-preview-max-width, 100%));max-height:260px;overflow:hidden;border-radius:18px}.video-crop-stage:fullscreen .video-crop-stage__surface{width:min(100%,calc((100dvh - 48px) * var(--video-crop-aspect-ratio, 1)));max-width:none;max-height:calc(100dvh - 48px)}.video-crop-stage__video,.video-crop-stage__image{display:block;width:100%;height:100%;max-width:100%;border-radius:18px;object-fit:contain;background:#0e1824}.video-crop-stage__overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.stacked-preview-stage{min-height:160px;display:grid;place-items:center;padding:12px;border-radius:18px;background:linear-gradient(135deg,#11243b0f,#1f5f781f),#dce6f1;border:1px solid rgba(17,36,59,.12)}.stacked-preview-stage__surface{width:min(100%,240px);aspect-ratio:600 / 1080;overflow:hidden;border-radius:18px;background:#0e1824}.stacked-preview-stage__image{display:block;width:100%;height:100%;object-fit:cover;background:#0e1824}.stacked-preview-placeholder{width:100%;height:100%;display:grid;place-items:center;padding:18px;text-align:center;color:#ffffffb8}.video-crop-selection{position:absolute;border:2px solid #ffffff;border-radius:14px;background:#ffffff1a;box-shadow:0 0 0 9999px #11243b6b,0 12px 28px #11243b3d;cursor:move;pointer-events:auto;touch-action:none;-webkit-user-select:none;user-select:none}.video-crop-selection.is-white{border-color:#fff;background:#ffffff1f}.video-crop-selection.is-green{border-color:#4fe07a;background:#4fe07a24}.video-crop-selection__label{position:absolute;top:10px;left:10px;padding:4px 7px;border-radius:999px;background:#11243bd6;color:#fff;font-size:.74rem;font-weight:700;letter-spacing:.02em}.clip-editor__footer{justify-content:flex-end}.clip-editor__footer--stacked{gap:8px}.clip-editor__footer--stacked button{padding:10px 14px}@media (max-width: 980px){.stacked-preview-layout,.publish-layout{grid-template-columns:minmax(0,1fr)}.stacked-preview-layout.is-preview-only .stacked-preview-panel{max-width:none}.stacked-preview-stage__surface{width:min(100%,280px)}}.video-crop-selection.is-green .video-crop-selection__label{background:#155a2ae0}.video-crop-selection__handle{position:absolute;width:14px;height:14px;padding:0;border:2px solid #11243b;border-radius:50%;background:#fff;box-shadow:0 4px 12px #11243b29}.video-crop-selection.is-green .video-crop-selection__handle{border-color:#0d5b28;background:#4fe07a}.video-crop-selection__handle:hover{transform:none;box-shadow:0 4px 12px #11243b29}.video-crop-selection__handle.is-nw{top:-7px;left:-7px;cursor:nwse-resize}.video-crop-selection__handle.is-n{top:-7px;left:calc(50% - 7px);cursor:ns-resize}.video-crop-selection__handle.is-ne{top:-7px;right:-7px;cursor:nesw-resize}.video-crop-selection__handle.is-e{top:calc(50% - 7px);right:-7px;cursor:ew-resize}.video-crop-selection__handle.is-se{right:-7px;bottom:-7px;cursor:nwse-resize}.video-crop-selection__handle.is-s{bottom:-7px;left:calc(50% - 7px);cursor:ns-resize}.video-crop-selection__handle.is-sw{bottom:-7px;left:-7px;cursor:nesw-resize}.video-crop-selection__handle.is-w{top:calc(50% - 7px);left:-7px;cursor:ew-resize}.messages-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;display:grid;place-items:center;padding:24px;background:#08101894;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.messages-modal{width:min(1200px,100%);height:min(82dvh,860px);display:grid;grid-template-rows:auto 1fr;border:1px solid rgba(17,36,59,.08);border-radius:24px;background:#fffffff2;box-shadow:0 24px 80px #08101859;overflow:hidden}.messages-modal__header{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;padding:22px 24px 0}.messages-modal__header h2{margin:0;letter-spacing:-.03em}.messages-modal__body{min-height:0;overflow:auto;padding:0 24px 24px}.messages-modal__body--logs{padding-top:8px}.messages-modal__body table{min-width:840px}.logs-list--modal{margin-top:0;padding-left:20px}@media (max-width: 860px){.messages-modal-backdrop{padding:12px}.messages-modal{height:min(90dvh,860px)}}.dashboard-header__title-group{display:grid;gap:8px;flex-shrink:0;align-content:center}.dashboard-header__legal-nav{display:flex;flex-wrap:wrap;gap:6px 12px}.dashboard-header__legal-nav a{font-size:.78rem;font-weight:600;color:#11243bb8;text-decoration:none}.dashboard-header__legal-nav a:hover{text-decoration:underline}.legal-page{height:100%;overflow:auto;padding:24px 14px 40px}.legal-page__container{max-width:860px;margin:0 auto;padding:26px 24px;border:1px solid rgba(17,36,59,.1);border-radius:24px;background:#ffffffe6;box-shadow:0 24px 80px #11243b14}.legal-page__back-link{display:inline-flex;align-items:center;margin-bottom:14px;color:#1f5f78;font-weight:600;text-decoration:none}.legal-page__back-link:hover{text-decoration:underline}.legal-page h1{margin:0 0 6px;font-size:clamp(1.7rem,3vw,2.25rem);letter-spacing:-.03em}.legal-page__updated-at{margin:0 0 22px;color:#11243ba3}.legal-page section+section{margin-top:20px}.legal-page h2{margin:0 0 8px;font-size:clamp(1.05rem,1.8vw,1.25rem);letter-spacing:-.015em}.legal-page p{margin:0;color:#11243be6}@media (max-width: 860px){.dashboard-header__title-group{width:100%}}@media (max-width: 640px){.legal-page{padding:14px 10px 24px}.legal-page__container{padding:18px 14px;border-radius:18px}}
