:root{color:#172033;background:#eef2f7;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;line-height:1.5;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell.ant-admin-shell{background:#eef2f7;min-height:100vh;padding:24px}.auth-shell{align-items:center;background:linear-gradient(135deg,rgba(15,118,110,.12),transparent 34%),linear-gradient(315deg,rgba(37,99,235,.1),transparent 32%),#eef2f7;display:grid;min-height:100vh;padding:24px}.login-card{box-shadow:0 24px 70px #0f172a24;margin:0 auto;max-width:440px;width:100%}.login-card .ant-card-body{display:grid;gap:18px;padding:28px}.login-brand{width:100%}.login-brand h1,.app-brand h4,.app-header h2,.panel-heading h3,.workspace-card h3,.ticket-detail h4{margin:0}.login-brand h1{font-size:28px}.login-copy{color:#637083;margin:0}.login-form .ant-form-item{margin-bottom:14px}.login-submit{margin-top:4px}.app-layout{align-items:stretch}.app-sidebar.ant-admin-sidebar{border:1px solid #dbe3ef;border-radius:8px;box-shadow:0 18px 45px #0f172a14;height:calc(100vh - 48px);overflow:hidden;position:sticky;top:24px}.ant-admin-sidebar .ant-layout-sider-children{display:flex;flex-direction:column;gap:18px;overflow:auto;padding:18px 12px}.app-brand{align-items:center;display:flex;gap:12px;padding:0 4px}.brand-mark{align-items:center;background:#0f766e;border-radius:8px;color:#fff;display:inline-flex;flex:0 0 auto;height:40px;justify-content:center;width:40px}.app-nav.ant-menu{background:transparent;border-inline-end:0}.app-nav .ant-menu-item{border-radius:8px;margin-inline:0;width:100%}.app-nav .ant-menu-item-selected{background:#0f766e;color:#fff}.sidebar-metrics{display:grid;gap:8px;padding:0 4px}.sidebar-metrics .ant-tag{align-items:center;border-radius:8px;display:inline-flex;gap:8px;margin:0;min-height:34px;padding:6px 10px;width:100%}.admin-session-card{margin-top:auto}.admin-session-card .ant-card-body{padding:10px}.admin-session-card .ant-space{width:100%}.session-avatar{background:#e0f2fe;color:#0369a1}.session-copy{display:grid;line-height:1.25;min-width:0}.session-copy .ant-typography{margin:0}.app-content{background:transparent;min-width:0;padding-left:24px}.app-header{align-items:flex-start;display:flex;gap:24px;justify-content:space-between;margin:0 0 16px}.app-header h2{align-items:center;display:flex;gap:10px}.header-subtitle{display:block;margin-top:6px}.content-panel{max-width:1280px;min-height:calc(100vh - 48px)}.content-error{margin-bottom:14px}.loading-chip{align-items:center;background:#eff6ff;border:1px solid #bfdbfe;border-radius:999px;color:#1d4ed8;font-size:12px;font-weight:800;min-height:30px;padding:4px 10px}.eyebrow{color:#0f766e;font-size:12px;font-weight:800;letter-spacing:0;margin:0;text-transform:uppercase}.project-panel,.feedback-workspace{min-width:0}.workspace-card,.project-list-card,.project-editor-card,.ticket-list-card,.ticket-detail{border-color:#dbe3ef;box-shadow:0 14px 35px #0f172a0f}.workspace-card>.ant-card-head{align-items:center}.filters-row{margin-bottom:16px}.filters-row .ant-input-search,.filters-row .ant-select,.project-form .ant-input,.project-form .ant-input-group-wrapper,.project-form .ant-select{width:100%}.field-label{color:#435168;display:block;font-size:13px;font-weight:700;margin-bottom:6px}.ticket-layout{margin-top:14px;min-height:560px}.ticket-list-card .ant-card-body{padding:8px}.ticket-list{max-height:720px;overflow:auto}.ticket-row{border:1px solid transparent;border-radius:8px;cursor:pointer;padding:12px;transition:background .18s ease,border-color .18s ease,box-shadow .18s ease}.ticket-row:hover,.project-row:hover{background:#f8fafc}.ticket-row.is-selected,.project-row.is-selected{background:#f0fdfa;border-color:#0f766e;box-shadow:0 0 0 3px #0f766e1a}.ticket-thumb,.ticket-thumb .ant-image-img,.ticket-thumb.ant-image-img{aspect-ratio:4 / 3;background:#e2e8f0;border-radius:6px;height:64px;object-fit:cover;width:84px}.ticket-snippet{display:block;max-width:420px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ticket-detail{min-width:0}.ticket-detail .ant-card-body{min-height:560px}.detail-screenshot,.detail-screenshot .ant-image-img,.detail-screenshot.ant-image-img{background:#e2e8f0;border:1px solid #dbe3ef;border-radius:8px;display:block;margin:0 0 14px;max-height:360px;object-fit:contain;width:100%}.ticket-comment{background:#f8fafc;border-radius:8px;margin:0 0 14px;padding:12px}.ticket-meta{margin:0 0 14px}.ticket-meta .ant-descriptions-item-content{overflow-wrap:anywhere}.status-form{margin-top:16px}.status-pill{align-items:center;border-radius:999px;display:inline-flex;font-size:12px;font-weight:800;margin-inline-end:0;min-height:24px;padding:3px 9px;white-space:nowrap}.status-NEW{background:#dbeafe;color:#1d4ed8}.status-IN_PROGRESS{background:#fef3c7;color:#92400e}.status-DONE{background:#dcfce7;color:#166534}.status-REJECTED{background:#fee2e2;color:#b91c1c}.panel-heading,.snippet-header{align-items:center;display:flex;gap:12px;justify-content:space-between}.project-list-card .ant-card-body{padding:0}.project-list{max-height:640px;overflow:auto}.project-row{border:1px solid transparent;cursor:pointer;padding:12px 16px;transition:background .18s ease,border-color .18s ease,box-shadow .18s ease}.project-key{max-width:126px;overflow:hidden;text-overflow:ellipsis}.project-editor-card .ant-card-body{padding:8px 20px 20px}.project-form{max-width:900px}.section-label{align-items:center;color:#172033;display:inline-flex;gap:8px;font-size:14px;font-weight:800;margin:4px 0 14px}.widget-color-collapse{margin-bottom:18px}.widget-color-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.widget-color-field{margin-bottom:0}.color-preview{border:1px solid rgba(15,23,42,.16);border-radius:6px;display:block;height:18px;width:18px}.snippet-box{display:grid;gap:10px}.snippet-header{flex-wrap:wrap}.snippet-actions,.snippet-format{align-items:center;display:flex;gap:8px}.snippet-actions{flex-wrap:wrap;justify-content:flex-end}.snippet-format-label{font-size:12px}.snippet-format .ant-select{min-width:132px}.snippet-path{color:#64748b;font-size:12px;margin:0}pre{background:#111827;border-radius:8px;color:#d1fae5;font-size:12px;margin:0;max-height:420px;overflow:auto;padding:12px;white-space:pre-wrap}@media(max-width:991px){.app-shell.ant-admin-shell{padding:14px}.app-sidebar.ant-admin-sidebar{border-radius:0 8px 8px 0;height:100vh;top:0}.app-content{padding-left:0}.app-header{flex-direction:column}}.widget-page{background:transparent;overflow:hidden}.widget-shell{background:var(--widget-chat-bg, #f0fdf4);color:#172033;height:100vh;overflow:hidden}.widget-shell-send{background:#fff}.widget-icon-button{align-items:center;background:#ffffff29;border:1px solid rgba(255,255,255,.22);border-radius:8px;color:inherit;display:inline-flex;height:34px;justify-content:center;width:34px}.feedback-modal,.feedback-modal-content{height:100vh;min-height:0}.feedback-modal{background:#fff;overflow:hidden}.feedback-modal-content{display:flex;flex-direction:column;max-height:calc(100vh + -0px);overflow:hidden}.feedback-modal-header,.feedback-modal-footer{flex:0 0 auto}.feedback-modal-header{align-items:center;background:#fff;border-bottom:1px solid #dbe3ef;color:#172033;display:flex;justify-content:space-between;padding:12px 14px}.feedback-modal-header strong,.feedback-modal-header span{display:block}.feedback-modal-header span{color:#64748b;font-size:12px;max-width:min(680px,68vw);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.feedback-modal-body{display:grid;flex:1 1 auto;gap:10px;grid-template-columns:minmax(0,1fr);grid-template-rows:minmax(0,1fr) auto;height:min(76vh,820px);min-height:0;overflow:hidden;padding:10px}.feedback-canvas-panel,.feedback-form-panel{min-height:0;min-width:0}.feedback-canvas-panel{background:#fff;border:1px solid #dbe3ef;border-radius:8px;display:flex;flex-direction:column;overflow:hidden}.feedback-canvas-toolbar{align-items:center;background:#f8fafc;border-bottom:1px solid #dbe3ef;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;padding:8px 10px}.feedback-tool-group{align-items:center;display:inline-flex;flex-wrap:wrap;gap:6px}.feedback-tool-actions{margin-left:auto}.feedback-tool-button{align-items:center;background:#fff;border:1px solid #cbd5e1;border-radius:8px;color:#172033;display:inline-flex;height:34px;justify-content:center;min-width:34px;padding:0;width:34px}.feedback-tool-button.is-active,.feedback-tool-button:hover{border-color:#0f766e;color:#0f766e}.feedback-tool-button:disabled,.feedback-footer-button:disabled{cursor:not-allowed;opacity:.48}.feedback-color-swatch{border:2px solid rgba(255,255,255,.92);border-radius:999px;box-shadow:0 0 0 1px #1118272e;cursor:pointer;height:22px;padding:0;width:22px}.feedback-color-swatch.is-active{box-shadow:0 0 0 2px #0f766e,0 0 0 4px #0f766e29}.feedback-stroke-button{background:#fff;border:1px solid #cbd5e1;border-radius:8px;color:#172033;font-size:12px;font-weight:800;height:28px;min-width:30px;padding:0 8px}.feedback-stroke-button.is-active{border-color:#0f766e;color:#0f766e}.feedback-tool-text{background:#fff;border:1px solid #cbd5e1;border-radius:8px;color:#172033;height:30px;min-height:30px;padding:4px 8px;width:150px}.feedback-zoom-controls{padding-left:4px}.feedback-zoom-level{background:#fff;border:1px solid #cbd5e1;border-radius:8px;color:#172033;font-size:12px;font-weight:800;height:30px;min-width:52px;padding:0 8px}.feedback-canvas-meta{align-items:center;color:#64748b;display:inline-flex;font-size:12px;gap:6px;white-space:nowrap}.feedback-canvas-scroll{background:#111827;display:grid;flex:1;max-height:none;min-height:0;overflow:hidden;overscroll-behavior:contain;place-items:center;scrollbar-gutter:stable}.feedback-canvas-scroll.is-zoomed{overflow:auto;place-items:start}.feedback-canvas{cursor:crosshair;display:block;height:auto;margin:0 auto;max-height:100%;max-width:100%;touch-action:none;-webkit-user-select:none;user-select:none;width:auto}.feedback-canvas.is-panning{cursor:grab}.feedback-canvas.is-zoomed{max-height:none;max-width:none}.feedback-canvas.is-panning:active{cursor:grabbing}.feedback-capture-loading,.widget-empty{color:#64748b;margin:0;padding:16px;text-align:center}.feedback-form-panel{display:grid;gap:8px;width:100%}.feedback-comment{background:#fff;border:1px solid #cbd5e1;border-radius:8px;color:#172033;max-height:96px;min-height:64px;padding:9px 11px;resize:vertical;width:100%}.feedback-modal-footer{align-items:center;background:var(--widget-footer-bg, #ffffff);border-top:1px solid #dbe3ef;display:flex;gap:8px;justify-content:flex-end;padding:10px 14px}.feedback-footer-button,.widget-refresh{align-items:center;border-radius:8px;display:inline-flex;gap:7px;justify-content:center;min-height:38px;padding:8px 11px}.feedback-footer-button,.widget-refresh{background:var(--widget-secondary-btn-bg, #ffffff);border:1px solid var(--widget-secondary-btn-border, #cbd5e1);color:var(--widget-secondary-btn-text, #172033)}.feedback-primary{background:var(--widget-primary-btn-bg, #0f766e);border-color:transparent;color:var(--widget-primary-btn-text, #ffffff)}.widget-history-window{background:var(--widget-chat-bg, #f0fdf4);display:grid;grid-template-rows:auto minmax(0,1fr);height:100vh;overflow:hidden}.widget-header{align-items:center;background:var(--widget-header-bg, #0f766e);color:var(--widget-header-text, #ffffff);display:flex;justify-content:space-between;padding:14px}.widget-header strong,.widget-header span{display:block}.widget-header span{font-size:12px;max-width:290px;opacity:.8;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.widget-content{display:grid;gap:10px;min-height:0;overflow:auto;padding:12px}.widget-message{background:#ecfdf5;border:1px solid #bbf7d0;border-radius:8px;color:#166534;margin:0;padding:8px 10px}.widget-history{align-content:start}.widget-history-item{background:#fff;border:1px solid #dbe3ef;border-radius:8px;display:grid;gap:8px;padding:10px}.widget-history-item strong,.widget-history-item span{display:block}.widget-history-item span{color:#64748b;font-size:13px}.widget-history-item p{align-items:center;color:#166534;display:flex;gap:6px;margin:0}@media(max-width:640px){.feedback-modal-body{height:min(68vh,640px)}.feedback-canvas-toolbar{align-items:flex-start;flex-direction:column}.feedback-tool-actions{margin-left:0}.feedback-tool-text{width:min(100%,180px)}.feedback-modal-footer{align-items:stretch;flex-direction:column}}
