*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f2f2f7;--surface: #ffffff;--surface-secondary: #f2f2f7;--surface-elevated: #ffffff;--text: #1c1c1e;--text-secondary: #6e6e73;--text-tertiary: #aeaeb2;--border: rgba(0,0,0,.08);--border-strong: rgba(0,0,0,.12);--accent: #E8703A;--accent-light: rgba(232,112,58,.1);--accent-hover: #d5632f;--danger: #FF3B30;--danger-light: rgba(255,59,48,.1);--success: #34C759;--success-light: rgba(52,199,89,.1);--radius: 12px;--radius-sm: 8px;--radius-lg: 16px;--shadow: 0 1px 2px rgba(0,0,0,.04), 0 1px 4px rgba(0,0,0,.03);--shadow-md: 0 2px 8px rgba(0,0,0,.06), 0 1px 3px rgba(0,0,0,.04);--shadow-lg: 0 4px 16px rgba(0,0,0,.08), 0 2px 6px rgba(0,0,0,.04);--header-height: 52px;--transition: .15s ease}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"cv02","cv03","cv04","cv11"}::selection{background:var(--accent-light);color:var(--text)}.app{min-height:100dvh}.header{background:#ffffffd1;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--border);padding:0 20px;height:var(--header-height);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.header-brand{font-weight:700;font-size:16px;color:var(--text);display:flex;align-items:center;gap:6px;letter-spacing:-.3px;user-select:none}.header-brand span{color:var(--accent);font-weight:600}.header-left{display:flex;align-items:center;gap:0;height:100%}.header-nav{display:flex;align-items:center;height:100%;margin-left:24px;gap:0}.header-nav-item{display:flex;align-items:center;height:100%;padding:0 14px;border:none;background:transparent;cursor:pointer;font-size:13px;font-weight:500;font-family:inherit;color:var(--text-tertiary);border-bottom:2px solid transparent;transition:all var(--transition);letter-spacing:-.1px}.header-nav-item.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.header-nav-item:hover:not(.active){color:var(--text-secondary)}.header-actions{display:flex;align-items:center;gap:8px}.container{max-width:1200px;margin:0 auto;padding:24px 20px 48px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;border:none;cursor:pointer;transition:all var(--transition);font-family:inherit;white-space:nowrap;letter-spacing:-.1px;user-select:none}.btn:disabled{opacity:.45;cursor:not-allowed}.btn:active:not(:disabled){transform:scale(.97)}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 1px 2px #e8703a40}.btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 2px 6px #e8703a4d}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--surface-secondary);border-color:var(--border-strong)}.btn-danger{background:var(--danger-light);color:var(--danger)}.btn-danger:hover:not(:disabled){background:var(--danger);color:#fff}.btn-ghost{background:transparent;color:var(--text-secondary);padding:6px 10px}.btn-ghost:hover:not(:disabled){background:#0000000a;color:var(--text)}.btn-sm{padding:5px 10px;font-size:12px;border-radius:6px}.card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);overflow:hidden}.card-header{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;font-size:14px}.card-body{padding:20px}.form-group{margin-bottom:14px}.form-label{display:block;font-size:11px;font-weight:600;color:var(--text-secondary);margin-bottom:5px;text-transform:uppercase;letter-spacing:.5px}.form-input,.form-select,.form-textarea{width:100%;padding:9px 12px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;background:var(--surface);color:var(--text);transition:border-color var(--transition),box-shadow var(--transition);outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.form-textarea{resize:vertical;min-height:100px}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-tertiary)}.login-container{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(145deg,#f5f5f7,#e8e8ed)}.login-card{width:100%;max-width:380px;background:var(--surface);border-radius:20px;padding:40px 32px;box-shadow:0 8px 32px #00000014,0 2px 8px #0000000a;text-align:center}.login-title{font-size:22px;font-weight:700;margin-bottom:4px;letter-spacing:-.5px}.login-subtitle{color:var(--text-secondary);font-size:14px;margin-bottom:28px}.otp-inputs{display:flex;gap:8px;justify-content:center;margin-bottom:24px}.otp-input{width:46px;height:52px;text-align:center;font-size:22px;font-weight:700;border:1.5px solid var(--border-strong);border-radius:var(--radius-sm);font-family:inherit;outline:none;transition:border-color var(--transition),box-shadow var(--transition);background:var(--surface-secondary)}.otp-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light);background:var(--surface)}.error-message{color:var(--danger);font-size:13px;margin-top:12px;font-weight:500}.dashboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.dashboard-title{font-size:22px;font-weight:700;letter-spacing:-.4px}.templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:12px}.template-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:16px;transition:all var(--transition);cursor:pointer;box-shadow:var(--shadow)}.template-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong);transform:translateY(-1px)}.template-card-header{display:flex;align-items:center;gap:12px;margin-bottom:10px}.template-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;flex-shrink:0}.template-info h3{font-size:15px;font-weight:600;margin-bottom:2px;letter-spacing:-.2px}.template-info p{font-size:12px;color:var(--text-secondary);line-height:1.4}.template-meta{display:flex;gap:8px;font-size:12px;color:var(--text-secondary);flex-wrap:wrap}.template-meta span{display:flex;align-items:center;gap:4px}.template-actions{display:flex;gap:6px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.empty-state{text-align:center;padding:64px 24px;color:var(--text-secondary)}.empty-state h3{font-size:17px;font-weight:600;color:var(--text);margin-bottom:6px;letter-spacing:-.2px}.generator-input{min-height:120px;font-size:16px;line-height:1.6}.generating-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;gap:12px}.spinner{width:28px;height:28px;border:2.5px solid var(--border-strong);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.preview-container{max-width:420px;margin:0 auto}.preview-phone{background:var(--surface);border-radius:24px;border:1px solid var(--border);box-shadow:0 4px 24px #0000000f,0 1px 4px #0000000a;overflow:hidden}.preview-header{padding:16px 20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border)}.preview-header-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px}.preview-header h3{font-size:17px;font-weight:600}.preview-fields{padding:12px 16px 24px}.preview-field{padding:12px 0}.preview-field+.preview-field{border-top:1px solid var(--surface-secondary)}.preview-field-label{font-size:15px;font-weight:500;margin-bottom:2px;display:flex;align-items:center;gap:6px}.preview-field-description{font-size:13px;color:var(--text-secondary);margin-bottom:6px}.field-text-input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:15px;font-family:inherit;background:var(--surface-secondary);color:var(--text);outline:none}.field-text-input:focus{border-color:var(--accent)}.field-textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:15px;font-family:inherit;background:var(--surface-secondary);color:var(--text);outline:none;resize:vertical;min-height:80px}.field-checkbox{display:flex;align-items:center;justify-content:space-between}.toggle{width:50px;height:30px;border-radius:15px;background:var(--border);position:relative;cursor:pointer;transition:background .2s;flex-shrink:0}.toggle.active{background:var(--success)}.toggle:after{content:"";width:26px;height:26px;border-radius:13px;background:#fff;position:absolute;top:2px;left:2px;transition:transform .2s;box-shadow:0 1px 3px #00000026}.toggle.active:after{transform:translate(20px)}.field-number{display:flex;align-items:center;gap:12px}.field-number input{width:80px;text-align:center}.field-rating{display:flex;gap:4px}.field-rating-star{font-size:28px;cursor:pointer;transition:transform .1s;user-select:none}.field-rating-star:hover{transform:scale(1.15)}.field-counter{display:flex;align-items:center;gap:16px}.counter-btn{width:36px;height:36px;border-radius:18px;border:1px solid var(--border);background:var(--surface-secondary);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.counter-btn:hover{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}.counter-value{font-size:20px;font-weight:600;min-width:40px;text-align:center}.field-time input[type=time]{padding:8px 12px;border:1px solid var(--border);border-radius:8px;font-size:15px;font-family:inherit;background:var(--surface-secondary)}.field-section{margin-top:8px}.field-section-title{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);padding-bottom:4px}.field-divider{border:none;border-top:1px solid var(--border);margin:4px 0}.field-link input{width:100%}.editor-layout{display:grid;grid-template-columns:1fr 420px;gap:24px;align-items:start}@media(max-width:960px){.editor-layout{grid-template-columns:1fr}}.editor-sidebar{position:sticky;top:80px}.field-list{margin-top:16px}.field-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);margin-bottom:8px;background:var(--surface)}.field-item-type{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);background:var(--surface-secondary);padding:2px 6px;border-radius:4px;flex-shrink:0}.field-item-label{flex:1;font-size:14px;font-weight:500}.field-item-actions{display:flex;gap:4px}.field-item-actions button{width:28px;height:28px;border-radius:6px;border:none;background:transparent;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .15s}.field-item-actions button:hover{background:var(--surface-secondary);color:var(--text)}.field-item-actions button.delete:hover{background:var(--danger-light);color:var(--danger)}.picker-grid{display:flex;flex-wrap:wrap;gap:8px;padding:8px 0}.icon-option{width:40px;height:40px;border-radius:8px;border:2px solid transparent;background:var(--surface-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;transition:all .15s}.icon-option:hover{border-color:var(--border)}.icon-option.selected{border-color:var(--accent);background:var(--accent-light)}.color-option{width:36px;height:36px;border-radius:18px;border:3px solid transparent;cursor:pointer;transition:all .15s}.color-option:hover{transform:scale(1.1)}.color-option.selected{border-color:var(--text);box-shadow:inset 0 0 0 2px #fff}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:100px;font-size:12px;font-weight:600;background:var(--surface-secondary);color:var(--text-secondary)}.tabs{display:flex;gap:2px;background:#0000000a;border-radius:var(--radius-sm);padding:2px;margin-bottom:16px}.tab{flex:1;padding:7px 14px;border-radius:6px;border:none;background:transparent;cursor:pointer;font-size:13px;font-weight:500;font-family:inherit;color:var(--text-secondary);transition:all var(--transition)}.tab.active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px #00000014;font-weight:600}.dialog-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.dialog{background:var(--surface);border-radius:16px;padding:24px;max-width:400px;width:100%;box-shadow:0 20px 40px #00000026}.dialog h3{font-size:18px;margin-bottom:8px}.dialog p{color:var(--text-secondary);font-size:15px;margin-bottom:20px}.dialog-actions{display:flex;gap:8px;justify-content:flex-end}.add-field-dropdown{position:absolute;top:100%;right:0;margin-top:4px;width:260px;max-height:360px;overflow-y:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:50;padding:4px}.add-field-option{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;border:none;background:none;cursor:pointer;border-radius:6px;font-size:14px;font-family:inherit;color:var(--text);transition:background .1s;text-align:left}.add-field-option:hover{background:var(--surface-secondary)}.add-field-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--surface-secondary);border-radius:6px;font-size:14px;flex-shrink:0}.add-field-type{margin-left:auto;font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.3px}.preview-field-highlighted{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--radius-sm);background:#e8703a0f;animation:previewHighlightPulse 1.5s ease-in-out infinite}@keyframes previewHighlightPulse{0%,to{outline-color:var(--accent);background:#e8703a0f}50%{outline-color:#e8703a80;background:#e8703a08}}hr.field-divider.preview-field-highlighted{outline-offset:4px}.field-item-focused{box-shadow:inset 3px 0 0 var(--accent)}.env-switcher{display:flex;background:#0000000a;border-radius:6px;padding:2px;gap:1px}.env-btn{padding:3px 10px;border-radius:5px;border:none;background:transparent;cursor:pointer;font-size:11px;font-weight:600;font-family:inherit;color:var(--text-tertiary);transition:all var(--transition);text-transform:uppercase;letter-spacing:.5px}.env-btn.active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px #00000014}.env-btn:hover:not(.active){color:var(--text-secondary)}.env-badge{display:inline-flex;align-items:center;padding:1px 6px;border-radius:4px;font-size:10px;font-weight:700;letter-spacing:.5px;margin-left:8px;background:var(--accent-light);color:var(--accent);vertical-align:middle}.main-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:20px}.main-tab{padding:10px 20px;border:none;background:transparent;cursor:pointer;font-size:14px;font-weight:500;font-family:inherit;color:var(--text-tertiary);border-bottom:2px solid transparent;transition:all var(--transition);margin-bottom:-1px;letter-spacing:-.1px}.main-tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.main-tab:hover:not(.active){color:var(--text-secondary)}.u-page-header{margin-bottom:24px}.u-page-title{font-size:22px;font-weight:700;display:flex;align-items:center;gap:8px;letter-spacing:-.4px}.u-page-subtitle{font-size:14px;color:var(--text-secondary);margin-top:4px}.u-stats-overview{margin-bottom:28px}.u-stats-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.u-stats-row-secondary{margin-top:10px;grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.u-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;text-align:center;box-shadow:var(--shadow)}.u-stat-number{font-size:22px;font-weight:700;color:var(--text);line-height:1.2;letter-spacing:-.5px;font-variant-numeric:tabular-nums}.u-stat-desc{font-size:10px;font-weight:600;color:var(--text-tertiary);margin-top:3px;text-transform:uppercase;letter-spacing:.3px}.u-stat-card-mini{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;display:flex;align-items:center;gap:8px}.u-stat-mini-val{font-size:15px;font-weight:700;color:var(--text)}.u-stat-mini-label{font-size:12px;color:var(--text-secondary)}.u-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:16px}.u-search-wrap{flex:1;max-width:420px;position:relative}.u-search-input{width:100%;padding:10px 34px 10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;background:var(--surface);outline:none;transition:border-color .15s,box-shadow .15s}.u-search-input:focus{border-color:var(--text-secondary);box-shadow:0 0 0 3px #0000000a}.u-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:22px;height:22px;border-radius:11px;border:none;background:var(--surface-secondary);color:var(--text-secondary);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.u-search-clear:hover{background:var(--border);color:var(--text)}.u-sort-select{padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;background:var(--surface);color:var(--text);cursor:pointer;outline:none}.u-sort-select:focus{border-color:var(--text-secondary)}.u-sort-dir{width:38px;height:38px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-secondary);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .1s}.u-sort-dir:hover{background:var(--surface-secondary);color:var(--text)}.u-user-list{display:flex;flex-direction:column;gap:4px}.uc-card{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);box-shadow:var(--shadow)}.uc-card:hover{background:var(--surface-secondary);border-color:var(--border-strong)}.uc-card:active{transform:scale(.995)}.uc-avatar{width:36px;height:36px;border-radius:18px;background:var(--surface-secondary);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;flex-shrink:0;position:relative;border:1px solid var(--border)}.uc-online-dot{position:absolute;bottom:-1px;right:-1px;width:10px;height:10px;border-radius:5px;background:var(--success);border:2px solid var(--surface)}.uc-info{flex:1;min-width:0}.uc-name{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.uc-email{font-size:12px;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.uc-stats{display:flex;gap:14px}.uc-stat{display:flex;align-items:center;gap:4px;font-size:13px;color:var(--text-secondary);white-space:nowrap}.uc-stat-label{font-size:11px;font-weight:600;color:var(--text-tertiary);width:14px;text-align:center}.uc-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}.uc-status-pill{display:inline-flex;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;letter-spacing:.2px}.uc-last-active{font-size:11px;color:var(--text-tertiary);white-space:nowrap}.uc-arrow{font-size:18px;color:var(--text-tertiary);font-weight:300;flex-shrink:0}.ud-pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:20px;padding:16px 0}.ud-page-info{font-size:13px;color:var(--text-secondary)}.ud-page-total{margin-left:6px;color:var(--text-tertiary)}.ud-container{max-width:900px}.ud-back-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:none;background:var(--surface-secondary);color:var(--text-secondary);font-size:13px;font-weight:500;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;margin-bottom:20px}.ud-back-btn:hover{background:var(--border);color:var(--text)}.ud-profile{display:flex;align-items:flex-start;gap:18px;margin-bottom:24px}.ud-avatar{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--surface-secondary);color:var(--text-secondary);font-size:20px;font-weight:600;overflow:hidden;border:1px solid var(--border)}.ud-avatar img{width:100%;height:100%;object-fit:cover}.ud-profile-info{flex:1;min-width:0}.ud-name{font-size:20px;font-weight:700;line-height:1.2;margin-bottom:5px;letter-spacing:-.4px}.ud-meta-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:4px}.ud-meta-item{font-size:13px;color:var(--text-secondary)}.ud-meta-sep{color:var(--text-tertiary);font-size:13px}.ud-status-pill{display:inline-flex;padding:2px 10px;border-radius:4px;font-size:11px;font-weight:600}.ud-quick-stats{display:flex;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 0;margin-bottom:20px;overflow-x:auto;box-shadow:var(--shadow)}.ud-qstat{flex:1;text-align:center;min-width:80px;padding:0 12px}.ud-qstat-val{font-size:18px;font-weight:700;color:var(--text);line-height:1.2}.ud-qstat-label{font-size:10px;font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.3px;margin-top:2px}.ud-qstat-divider{width:1px;height:28px;background:var(--border);flex-shrink:0}.ud-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:20px}.ud-tab{padding:10px 20px;border:none;background:transparent;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s}.ud-tab:hover{color:var(--text)}.ud-tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.ud-billing{max-width:1100px}.ud-billing-loading{min-height:160px;flex-direction:column;gap:12px;color:var(--text-secondary);font-size:14px}.ud-billing-hero{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:16px;padding:20px 22px;margin-bottom:16px;background:linear-gradient(145deg,color-mix(in srgb,var(--surface) 92%,var(--accent) 8%) 0%,var(--surface) 55%,var(--surface-secondary) 100%);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.ud-billing-hero-text{flex:1;min-width:220px}.ud-billing-hero-title{margin:0 0 6px;font-size:17px;font-weight:600;letter-spacing:-.02em;color:var(--text-primary)}.ud-billing-hero-sub{margin:0;font-size:13px;line-height:1.5;color:var(--text-secondary);max-width:52ch}.ud-billing-hero-aside{flex-shrink:0;display:flex;align-items:center}.ud-billing-cta{display:inline-flex;align-items:center;justify-content:center;padding:10px 18px;font-size:13px;font-weight:600;color:#fff;background:var(--accent);border-radius:8px;text-decoration:none;transition:filter .15s,transform .12s}.ud-billing-cta:hover{filter:brightness(1.06);transform:translateY(-1px)}.ud-billing-note{font-size:13px;color:var(--text-secondary);font-style:italic}.ud-billing-meta{display:flex;flex-wrap:wrap;align-items:baseline;gap:10px 16px;margin-bottom:18px;padding:10px 14px;background:var(--surface-secondary);border:1px solid var(--border);border-radius:8px}.ud-billing-meta-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary)}.ud-billing-meta-value{font-size:12px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;color:var(--text-primary);word-break:break-all}.ud-billing-stats{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}.ud-billing-stat{min-width:140px;padding:14px 18px;background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:0 1px 2px #0000000a}.ud-billing-stat-label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);margin-bottom:6px}.ud-billing-stat-value{font-size:18px;font-weight:700;font-variant-numeric:tabular-nums;color:var(--text-primary);letter-spacing:-.02em}.ud-billing-empty{text-align:center;padding:24px}.ud-billing-empty-state{text-align:center;padding:48px 24px;border:1px dashed var(--border);border-radius:var(--radius);background:color-mix(in srgb,var(--surface-secondary) 80%,transparent)}.ud-billing-empty-title{margin:0 0 8px;font-size:15px;font-weight:600;color:var(--text-primary)}.ud-billing-empty-sub{margin:0;font-size:13px;color:var(--text-secondary);line-height:1.5}.ud-billing-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow)}.ud-billing-table{width:100%;border-collapse:collapse;font-size:13px}.ud-billing-table thead{background:var(--surface-secondary);border-bottom:1px solid var(--border)}.ud-billing-table th{text-align:left;padding:12px 14px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.ud-billing-table td{padding:14px;vertical-align:top;border-bottom:1px solid color-mix(in srgb,var(--border) 70%,transparent)}.ud-billing-table tbody tr:last-child td{border-bottom:none}.ud-billing-table tbody tr:hover{background:color-mix(in srgb,var(--surface-secondary) 55%,transparent)}.ud-billing-col-num{text-align:right;font-variant-numeric:tabular-nums}.ud-billing-col-link{text-align:center;white-space:nowrap}.ud-billing-cell-muted{color:var(--text-secondary);font-size:12px;white-space:nowrap}.ud-billing-kind{display:inline-block;padding:3px 8px;font-size:11px;font-weight:600;letter-spacing:.02em;color:var(--text-secondary);background:var(--surface-secondary);border:1px solid var(--border);border-radius:6px}.ud-billing-title{font-weight:600;color:var(--text-primary);line-height:1.35}.ud-billing-sub{margin-top:4px;font-size:12px;color:var(--text-secondary);line-height:1.4}.ud-billing-amount{font-weight:600;color:var(--text-primary)}.ud-billing-status{display:inline-block;padding:3px 8px;font-size:11px;font-weight:600;text-transform:capitalize;border-radius:6px}.ud-billing-status--ok{color:color-mix(in srgb,#15803d 90%,var(--text-primary));background:color-mix(in srgb,#15803d 12%,transparent)}.ud-billing-status--pending{color:color-mix(in srgb,#b45309 95%,var(--text-primary));background:color-mix(in srgb,#b45309 12%,transparent)}.ud-billing-status--bad{color:color-mix(in srgb,#b91c1c 95%,var(--text-primary));background:color-mix(in srgb,#b91c1c 12%,transparent)}.ud-billing-status--muted{color:var(--text-secondary);background:var(--surface-secondary)}.ud-billing-link{font-size:12px;font-weight:600;color:var(--accent);text-decoration:none}.ud-billing-link:hover{text-decoration:underline}.ud-billing-dash{color:var(--text-tertiary)}.ud-overview{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:16px}.ud-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.ud-card-title{font-size:12px;font-weight:600;padding:12px 16px;border-bottom:1px solid var(--border);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px}.ud-event-list{padding:4px 16px}.ud-event-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--surface-secondary)}.ud-event-row:last-child{border-bottom:none}.ud-event-name{font-size:13px;color:var(--text);white-space:nowrap;min-width:120px}.ud-event-bar-wrap{flex:1;height:4px;background:var(--surface-secondary);border-radius:2px;overflow:hidden;min-width:40px}.ud-event-bar{height:100%;background:var(--text-tertiary);border-radius:2px;min-width:3px;transition:width .4s ease}.ud-event-count{font-size:13px;font-weight:600;color:var(--text);min-width:36px;text-align:right;font-variant-numeric:tabular-nums}.ud-sessions{padding:4px 16px}.ud-sessions-scroll{max-height:520px;overflow-y:auto}.ud-sessions-loading{display:flex;justify-content:center;align-items:center;padding:40px 0}.ud-sessions-pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px 16px;border-top:1px solid var(--surface-secondary)}.ud-session{padding:10px 0;border-bottom:1px solid var(--surface-secondary)}.ud-session:last-child{border-bottom:none}.ud-session-main{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.ud-session-date{font-size:13px;color:var(--text);font-weight:500}.ud-session-duration{font-size:12px;font-weight:600;color:var(--text-secondary);background:var(--surface-secondary);padding:2px 8px;border-radius:4px}.ud-session-details{display:flex;gap:12px;font-size:12px;color:var(--text-tertiary)}.ud-empty{text-align:center;padding:48px 24px}.ud-empty h3{font-size:15px;font-weight:600;color:var(--text);margin-bottom:6px}.ud-empty p{font-size:13px;color:var(--text-secondary)}.ud-activity-filters{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}.ud-filter-chip{padding:5px 12px;border:1px solid var(--border);border-radius:4px;background:var(--surface);color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.ud-filter-chip:hover{border-color:var(--text-secondary);color:var(--text)}.ud-filter-chip.active{background:var(--text);border-color:var(--text);color:var(--surface)}.ud-timeline{display:flex;flex-direction:column;gap:6px}.ud-timeline-item{display:flex;gap:12px;align-items:flex-start}.ud-timeline-dot{width:8px;height:8px;border-radius:4px;background:var(--border);flex-shrink:0;margin-top:14px}.ud-timeline-content{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;min-width:0}.ud-timeline-header{display:flex;justify-content:space-between;align-items:center;gap:10px}.ud-timeline-header strong{font-size:13px}.ud-timeline-time{font-size:11px;color:var(--text-tertiary);white-space:nowrap}.ud-timeline-screen{display:inline-block;font-size:11px;color:var(--text-secondary);background:var(--surface-secondary);padding:2px 8px;border-radius:3px;margin-top:4px}.ud-timeline-data{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.ud-data-tag{font-size:11px;background:var(--surface-secondary);padding:2px 8px;border-radius:3px;color:var(--text-secondary);font-family:SF Mono,Fira Code,monospace}.ud-data-key{color:var(--text-tertiary)}.ud-section-title{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px;margin-top:24px;margin-bottom:10px}.ud-template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:8px}.ud-template-card{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm)}.ud-template-published{border-left:3px solid var(--success)}.ud-template-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;color:#fff}.ud-template-body{flex:1;min-width:0}.ud-template-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ud-template-meta{display:flex;gap:10px;font-size:12px;color:var(--text-tertiary);margin-top:2px}.ud-template-status.active{color:var(--success);font-weight:500}.ud-template-status.inactive{color:var(--text-tertiary)}.preview-detail{border-radius:var(--radius-sm)}.preview-detail-children{margin-top:8px;padding:8px 12px;background:var(--surface-secondary);border-radius:var(--radius-sm);border-left:3px solid var(--accent)}.preview-detail-children .preview-field{padding:8px 0}.preview-detail-children .preview-field:first-child{padding-top:0}.preview-detail-children .preview-field:last-child{padding-bottom:0}.ud-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--accent);color:#fff;font-size:11px;font-weight:600;margin-left:6px}.ud-notes-tab{padding:0}.ud-notes-input-section{display:flex;flex-direction:column;gap:8px;padding:16px 0;margin-bottom:16px;border-bottom:1px solid var(--border)}.ud-notes-textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-family:inherit;outline:none;resize:vertical;min-height:72px;background:var(--surface-secondary);transition:border-color .15s}.ud-notes-textarea:focus{border-color:var(--accent)}.ud-notes-list{display:flex;flex-direction:column;gap:10px}.ud-note-card{padding:12px 14px;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.ud-note-body{font-size:13px;line-height:1.5;white-space:pre-wrap;color:var(--text-primary)}.ud-note-footer{display:flex;justify-content:space-between;align-items:center;margin-top:10px}.ud-note-time{font-size:11px;color:var(--text-tertiary)}.ud-note-delete{background:none;border:none;color:var(--danger, #ef4444);font-size:11px;cursor:pointer;padding:2px 6px;border-radius:4px}.ud-note-delete:hover{background:#ef44441a;text-decoration:underline}.ud-ai-tab{padding-top:8px}.ud-ai-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.ud-ai-header-label{font-size:14px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.ud-ai-refresh-btn{display:inline-flex;align-items:center;gap:4px}.spinner-sm{display:inline-block;width:12px;height:12px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}.ud-ai-access-panel{margin-bottom:20px}.ud-ai-access-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}.ud-ai-access-card{border:1px solid var(--border);border-radius:var(--radius);padding:16px;background:var(--surface);display:flex;flex-direction:column;gap:10px}.ud-ai-access-card.success{border-color:#bbf7d0;background:color-mix(in srgb,#22c55e 4%,var(--surface))}.ud-ai-access-card.danger{border-color:#fecaca;background:color-mix(in srgb,#ef4444 4%,var(--surface))}.ud-ai-access-card.neutral{border-color:var(--border)}.ud-ai-access-card-header{display:flex;align-items:center;gap:8px}.ud-ai-access-card-icon{font-size:16px}.ud-ai-access-card-title{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px}.ud-ai-access-card-status{font-size:20px;font-weight:700;color:var(--text-primary)}.ud-ai-access-toggle{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text-primary);transition:background .15s,border-color .15s,box-shadow .15s,color .15s;box-shadow:0 1px 2px #0000000d}.ud-ai-access-toggle:hover:not(:disabled){background:var(--surface-secondary)}.ud-ai-access-toggle:disabled{opacity:.55;cursor:not-allowed}.ud-ai-access-toggle--disable{border-color:color-mix(in srgb,var(--text-secondary) 40%,var(--border));color:var(--text-primary)}.ud-ai-access-toggle--disable:hover:not(:disabled){border-color:color-mix(in srgb,#ef4444 55%,var(--border));background:color-mix(in srgb,#ef4444 7%,var(--surface));color:#b91c1c;box-shadow:0 1px 3px #ef44441f}.ud-ai-access-toggle--enable{border-color:color-mix(in srgb,#22c55e 55%,var(--border));color:#15803d;background:color-mix(in srgb,#22c55e 9%,var(--surface))}.ud-ai-access-toggle--enable:hover:not(:disabled){background:color-mix(in srgb,#22c55e 16%,var(--surface));border-color:#22c55e;box-shadow:0 1px 3px #22c55e26}.ud-ai-budget-bar-wrap{height:6px;background:var(--border);border-radius:3px;overflow:hidden}.ud-ai-budget-bar-fill{height:100%;border-radius:3px;background:var(--accent);transition:width .3s}.ud-ai-budget-bar-fill.over{background:#ef4444}.ud-ai-budget-bar-labels{display:flex;justify-content:space-between;font-size:11px;color:var(--text-secondary)}.ud-ai-budget-breakdown{display:flex;gap:10px;font-size:11px;color:var(--text-secondary)}.ud-ai-budget-how{font-size:11px;line-height:1.45;color:var(--text-secondary);margin:0 0 8px}.ud-ai-budget-how strong{color:var(--text-primary)}.ud-ai-budget-rows{display:flex;flex-direction:column;gap:4px;margin-top:8px;font-size:12px}.ud-ai-budget-row{display:flex;justify-content:space-between;align-items:baseline;gap:10px}.ud-ai-budget-strong{font-weight:700;color:var(--text-primary)}.ud-ai-budget-row-em{font-weight:600;color:var(--text-primary);padding-top:6px;margin-top:4px;border-top:1px solid var(--border)}.ud-ai-budget-row-em .ud-ai-budget-row-label{font-weight:600}.ud-ai-budget-row-label{color:var(--text-secondary);flex:1;min-width:0}.ud-ai-budget-row-val{font-variant-numeric:tabular-nums;white-space:nowrap}.ud-ai-budget-muted{color:var(--text-secondary);font-weight:400}.ud-ai-budget-note{font-size:10px;line-height:1.4;color:var(--text-secondary);margin:2px 0 6px;padding-left:2px}.ud-ai-budget-check{font-size:10px;color:var(--text-secondary);margin:4px 0 0;font-variant-numeric:tabular-nums}.ud-ai-budget-warn{color:#d97706;font-weight:600}.ud-ai-budget-form{margin-top:2px}.ud-ai-budget-input-row{display:flex;align-items:center;gap:6px}.ud-ai-budget-dollar{font-size:13px;font-weight:600;color:var(--text-secondary)}.ud-ai-budget-input{width:80px;padding:5px 8px;border:1px solid var(--border);border-radius:6px;font-size:13px;background:var(--surface);color:var(--text-primary);flex:1}.ud-ai-budget-input:focus{outline:none;border-color:var(--accent)}.ud-ai-cost-summary{display:flex;align-items:center;gap:16px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:4px}.ud-ai-cost-item{display:flex;flex-direction:column;gap:2px}.ud-ai-cost-label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px}.ud-ai-cost-value{font-size:13px;font-weight:600;color:var(--text-primary)}.ud-ai-cost-sep{width:1px;height:28px;background:var(--border)}.ud-ai-cost-visual{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.ud-ai-cost-visual-header{margin-bottom:12px}.ud-ai-cost-visual-title{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary)}.ud-ai-cost-visual-hint{display:block;font-size:12px;color:var(--text-secondary);margin-top:4px;line-height:1.35}.ud-ai-charts{display:flex;flex-direction:column;gap:22px}.ud-ai-charts--loading,.ud-ai-charts--empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:28px 20px;text-align:center;font-size:13px;color:var(--text-secondary);background:var(--surface-secondary);border-radius:var(--radius);border:1px dashed var(--border)}.ud-ai-chart-block{margin:0}.ud-ai-chart-heading{margin-bottom:10px}.ud-ai-chart-title{display:block;font-size:14px;font-weight:700;color:var(--text-primary)}.ud-ai-chart-sub{display:block;font-size:12px;color:var(--text-secondary);margin-top:3px;line-height:1.35}.ud-ai-chart-scroll{overflow-x:auto;padding-bottom:6px;-webkit-overflow-scrolling:touch}.ud-ai-chart-panel{min-width:min(100%,920px)}.ud-ai-chart-panel-row{display:flex;align-items:flex-start;gap:2px}.ud-ai-chart-y-title{writing-mode:vertical-rl;transform:rotate(180deg);font-size:11px;font-weight:600;color:var(--text-secondary);width:22px;flex-shrink:0;padding-top:4px;letter-spacing:.04em;user-select:none;cursor:help}.ud-ai-chart-y-ticks{display:flex;flex-direction:column;justify-content:space-between;width:62px;flex-shrink:0;font-size:10px;font-weight:500;color:var(--text-secondary);font-variant-numeric:tabular-nums;text-align:right;padding:4px 8px 4px 0;line-height:1;border-right:1px solid var(--border)}.ud-ai-chart-y-tick{display:block}.ud-ai-chart-chart-shell{flex:1;min-width:240px}.ud-ai-chart-chart-body{position:relative;background:color-mix(in srgb,var(--surface-secondary) 45%,var(--surface));border:1px solid var(--border);border-radius:6px 6px 0 0;overflow:visible}.ud-ai-chart-grid{position:absolute;inset:0;pointer-events:none}.ud-ai-chart-grid-line{position:absolute;left:0;right:0;height:0;border-top:1px dashed color-mix(in srgb,var(--border) 85%,transparent);opacity:.95}.ud-ai-chart-bar-area{position:absolute;inset:0;display:flex;align-items:flex-end;gap:6px;padding:8px 10px 6px}.ud-ai-chart-bar-col{flex:1 1 0;min-width:28px;max-width:88px;height:100%;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;position:relative}.ud-ai-chart-bar-col.is-hover .ud-ai-chart-bar{box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 40%,transparent);filter:brightness(1.06)}.ud-ai-chart-bar-track{width:100%;height:100%;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;min-height:0}.ud-ai-chart-bar{width:100%;max-width:34px;border-radius:5px 5px 2px 2px;background:linear-gradient(180deg,var(--accent) 0%,color-mix(in srgb,var(--accent) 68%,#1a1a1a) 100%);min-height:1px;transition:height .2s ease,box-shadow .15s,filter .15s}.ud-ai-chart-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);z-index:40;padding:9px 12px;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px #00000024;pointer-events:none;min-width:128px;max-width:220px;text-align:center}.ud-ai-chart-tooltip-label{display:block;font-size:11px;font-weight:600;color:var(--text-primary);line-height:1.3}.ud-ai-chart-tooltip-val{display:block;margin-top:5px;font-size:13px;font-weight:700;font-variant-numeric:tabular-nums;color:var(--accent)}.ud-ai-chart-x-labels-row{display:flex;gap:6px;padding:8px 10px 10px;border:1px solid var(--border);border-top:none;border-radius:0 0 6px 6px;background:var(--surface);align-items:flex-start}.ud-ai-chart-x-label-cell{flex:1 1 0;min-width:28px;max-width:88px;text-align:center}.ud-ai-chart-x-label{font-size:10px;color:var(--text-secondary);line-height:1.25;word-break:break-word;display:block}.ud-ai-chart-x-caption{margin:10px 0 0;font-size:11px;color:var(--text-secondary);text-align:center;line-height:1.45}.ud-ai-stats{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap}.ud-ai-stat-card{flex:1;min-width:120px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;text-align:center}.ud-ai-stat-card.ud-ai-stat-cost{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 5%,var(--surface))}.ud-ai-stat-val{font-size:20px;font-weight:700;color:var(--text);margin-bottom:4px}.ud-ai-stat-cost .ud-ai-stat-val{color:var(--accent)}.ud-ai-stat-label{font-size:11px;font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.ud-ai-date-range{display:flex;gap:6px;align-items:center;font-size:12px;color:var(--text-secondary);margin-bottom:20px}.ud-ai-convos{display:flex;flex-direction:column}.ud-ai-convo-block{border-bottom:1px solid var(--border)}.ud-ai-convo-block:last-child{border-bottom:none}.ud-ai-convo-header{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;width:100%;background:none;border:none;cursor:pointer;text-align:left;color:var(--text);font-size:13px;transition:background .15s}.ud-ai-convo-header:hover,.ud-ai-convo-header.expanded{background:var(--surface-secondary, rgba(118, 118, 128, .06))}.ud-ai-convo-chevron{font-size:10px;color:var(--text-tertiary);margin-top:3px;flex-shrink:0;width:14px;transition:transform .15s}.ud-ai-convo-summary{flex:1;min-width:0}.ud-ai-convo-preview{display:block;font-weight:500;color:var(--text);margin-bottom:6px;line-height:1.4}.ud-ai-convo-tags{display:flex;gap:6px;flex-wrap:wrap}.ud-ai-tag{font-size:11px;padding:2px 8px;border-radius:10px;background:var(--surface-secondary, rgba(118, 118, 128, .08));color:var(--text-secondary);white-space:nowrap}.ud-ai-tag.ud-ai-tag-cost{background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent);font-weight:600}.ud-ai-convo-date{font-size:11px;color:var(--text-tertiary);white-space:nowrap;flex-shrink:0;margin-top:2px}.ud-ai-exchanges{border-top:1px solid var(--border);background:color-mix(in srgb,var(--surface-secondary, rgba(118, 118, 128, .08)) 50%,transparent);padding:0 16px 12px}.ud-ai-convo-meta-bar{display:flex;justify-content:space-between;align-items:center;padding:10px 0;font-size:11px;color:var(--text-tertiary);border-bottom:1px solid var(--border);margin-bottom:8px}.ud-ai-convo-meta-bar code{font-size:10px;background:var(--surface);padding:1px 6px;border-radius:4px;color:var(--text-secondary)}.ud-ai-exchange{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid color-mix(in srgb,var(--border) 50%,transparent)}.ud-ai-exchange:last-child{border-bottom:none}.ud-ai-exchange-num{font-size:11px;font-weight:700;color:var(--text-tertiary);min-width:28px;padding-top:2px}.ud-ai-exchange-content{flex:1;min-width:0}.ud-ai-msg{margin-bottom:10px;padding:10px 14px;border-radius:10px;font-size:13px;line-height:1.6}.ud-ai-msg-user{background:color-mix(in srgb,var(--accent) 8%,var(--surface));border-left:3px solid var(--accent)}.ud-ai-msg-assistant{background:var(--surface);border-left:3px solid var(--success, #34C759)}.ud-ai-msg-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px}.ud-ai-msg-user .ud-ai-msg-label{color:var(--accent)}.ud-ai-msg-assistant .ud-ai-msg-label{color:var(--success, #34C759)}.ud-ai-msg-text{color:var(--text);white-space:pre-wrap;word-break:break-word}.ud-ai-msg-text.truncated{position:relative}.ud-ai-expand-btn{background:none;border:none;color:var(--accent);font-size:12px;font-weight:500;cursor:pointer;padding:4px 0;margin-top:4px}.ud-ai-expand-btn:hover{text-decoration:underline}.ud-ai-exchange-meta{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}.ud-ai-tag-sm{font-size:10px;padding:2px 7px;border-radius:8px;background:var(--surface-secondary, rgba(118, 118, 128, .08));color:var(--text-secondary);white-space:nowrap}.ud-ai-tag-sm.ud-ai-tag-model{font-family:SF Mono,Menlo,Consolas,monospace;font-size:10px}.ud-ai-tag-sm.ud-ai-tag-tool{background:color-mix(in srgb,var(--accent) 10%,transparent);color:var(--accent)}.ud-ai-tool-toggle{border:none;cursor:pointer;font-weight:600;transition:background .15s}.ud-ai-tool-toggle:hover{background:color-mix(in srgb,var(--accent) 18%,transparent)}.ud-ai-tool-toggle.active{background:color-mix(in srgb,var(--accent) 16%,transparent)}.ud-ai-tag-sm.ud-ai-tag-cost{font-weight:600;background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent)}.ud-ai-tag-sm.ud-ai-tag-time{color:var(--text-tertiary)}.ud-ai-tool-details{margin-top:10px;border:1px solid var(--border);border-radius:10px;overflow:hidden;background:var(--surface)}.ud-ai-tool-call{border-bottom:1px solid color-mix(in srgb,var(--border) 60%,transparent)}.ud-ai-tool-call:last-child{border-bottom:none}.ud-ai-tool-call-header{display:flex;align-items:center;gap:8px;padding:8px 12px;background:color-mix(in srgb,var(--text) 3%,transparent)}.ud-ai-tool-call-idx{font-size:10px;font-weight:700;color:var(--text-tertiary);min-width:18px;height:18px;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--text) 8%,transparent);border-radius:9px}.ud-ai-tool-call-name{font-size:12px;font-weight:600;color:var(--accent);flex:1}.ud-ai-tool-call-dur{font-size:10px;color:var(--text-tertiary);font-variant-numeric:tabular-nums}.ud-ai-tool-call-cached{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--success, #34C759);background:color-mix(in srgb,var(--success, #34C759) 12%,transparent);padding:1px 6px;border-radius:6px}.ud-ai-tool-call-section{padding:6px 12px 8px}.ud-ai-tool-call-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-tertiary);margin-bottom:4px}.ud-ai-tool-call-json{font-size:11px;font-family:SF Mono,Menlo,Consolas,monospace;background:color-mix(in srgb,var(--text) 4%,transparent);border-radius:6px;padding:8px 10px;margin:0;overflow-x:auto;max-height:200px;overflow-y:auto;color:var(--text);line-height:1.5;white-space:pre-wrap;word-break:break-word}.ud-ai-search-bar{display:flex;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border)}.ud-ai-search-input{flex:1;padding:7px 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:13px;outline:none}.ud-ai-search-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 15%,transparent)}.ud-ai-pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding:14px 16px;border-top:1px solid var(--border)}.ud-ai-page-info{font-size:13px;color:var(--text-secondary);font-weight:500;min-width:100px;text-align:center}.ud-ai-msg-markdown h1,.ud-ai-msg-markdown h2,.ud-ai-msg-markdown h3{margin:8px 0 4px;line-height:1.3}.ud-ai-msg-markdown h1{font-size:16px}.ud-ai-msg-markdown h2{font-size:15px}.ud-ai-msg-markdown h3{font-size:14px}.ud-ai-msg-markdown p{margin:0 0 8px;line-height:1.5}.ud-ai-msg-markdown p:last-child{margin-bottom:0}.ud-ai-msg-markdown ul,.ud-ai-msg-markdown ol{margin:4px 0 8px;padding-left:20px}.ud-ai-msg-markdown li{margin-bottom:2px}.ud-ai-msg-markdown code{background:color-mix(in srgb,var(--text) 8%,transparent);padding:1px 5px;border-radius:4px;font-size:12px;font-family:SF Mono,Menlo,monospace}.ud-ai-msg-markdown pre{background:color-mix(in srgb,var(--text) 6%,transparent);border-radius:8px;padding:10px 12px;overflow-x:auto;margin:6px 0 8px}.ud-ai-msg-markdown pre code{background:none;padding:0;font-size:12px}.ud-ai-msg-markdown blockquote{border-left:3px solid var(--accent);margin:6px 0;padding:4px 12px;color:var(--text-secondary)}.ud-ai-msg-markdown table{border-collapse:collapse;width:100%;margin:6px 0;font-size:12px}.ud-ai-msg-markdown th,.ud-ai-msg-markdown td{border:1px solid var(--border);padding:5px 8px;text-align:left}.ud-ai-msg-markdown th{background:color-mix(in srgb,var(--text) 5%,transparent);font-weight:600}.ud-ai-msg-markdown strong{font-weight:600}.ud-ai-msg-markdown em{font-style:italic}.ud-ai-msg-markdown a{color:var(--accent);text-decoration:none}.ud-ai-msg-markdown a:hover{text-decoration:underline}.ud-storage-tab{animation:fadeIn .15s ease}.st-summary-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px}.st-summary-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px;text-align:center}.st-summary-val{font-size:22px;font-weight:700;color:var(--text);letter-spacing:-.5px}.st-summary-label{font-size:11px;font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.3px;margin-top:2px}.st-summary-cost .st-summary-val{color:var(--success)}.st-avatar-section{margin-bottom:16px}.st-avatar-link{display:inline-flex;align-items:center;gap:12px;padding:10px 16px 10px 10px;background:var(--surface);border:1px solid var(--border);border-radius:10px;text-decoration:none;color:inherit;transition:var(--transition)}.st-avatar-link:hover{border-color:var(--accent);box-shadow:var(--shadow)}.st-avatar-img{width:44px;height:44px;border-radius:50%;object-fit:cover}.st-avatar-label{font-size:13px;font-weight:500;color:var(--text-secondary)}.st-categories{display:flex;flex-direction:column;gap:6px}.st-category-card{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:10px;cursor:pointer;text-align:left;transition:var(--transition);color:inherit;font:inherit}.st-category-card:hover:not(:disabled){border-color:var(--accent);box-shadow:var(--shadow)}.st-category-card.empty{opacity:.45;cursor:default}.st-category-info{flex:1;min-width:0}.st-category-name{font-size:14px;font-weight:600;color:var(--text)}.st-category-stats{font-size:12px;color:var(--text-tertiary);margin-top:1px;display:flex;gap:5px}.st-category-chevron{font-size:18px;color:var(--text-tertiary);flex-shrink:0}.st-date-back{display:inline-flex;align-items:center;gap:4px;background:none;border:none;color:var(--accent);font-size:13px;font-weight:500;cursor:pointer;padding:0;margin-bottom:8px}.st-date-back:hover{text-decoration:underline}.st-date-title{font-size:17px;font-weight:700;color:var(--text);margin-bottom:4px;letter-spacing:-.3px}.st-date-file-count{font-size:12px;color:var(--text-tertiary);margin-bottom:14px}.st-date-list{display:flex;flex-direction:column;gap:4px;margin-top:8px}.st-date-row{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:8px;cursor:pointer;text-align:left;font:inherit;color:inherit;transition:var(--transition);width:100%}.st-date-row:hover{border-color:var(--accent);background:var(--surface-secondary)}.st-date-row-date{font-size:13px;font-weight:600;color:var(--text);flex:1}.st-date-row-meta{font-size:12px;color:var(--text-tertiary);display:flex;gap:5px;flex-shrink:0}.st-date-row-chevron{font-size:16px;color:var(--text-tertiary);flex-shrink:0}.st-search-wrap{position:relative}.st-search-input{width:100%;padding:8px 32px 8px 12px;border:1px solid var(--border);border-radius:8px;background:var(--surface);font-size:13px;color:var(--text);outline:none;transition:var(--transition);box-sizing:border-box}.st-search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #e8703a1a}.st-search-input::placeholder{color:var(--text-tertiary)}.st-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:16px;color:var(--text-tertiary);cursor:pointer;padding:0 4px;line-height:1}.st-search-clear:hover{color:var(--text)}.st-result-count{font-size:12px;color:var(--text-tertiary);margin-bottom:12px}.st-group{margin-bottom:20px}.st-group-header{display:flex;align-items:baseline;gap:10px;padding:6px 0;margin-bottom:8px;border-bottom:1px solid var(--border)}.st-group-title{font-size:13px;font-weight:600;color:var(--text)}.st-group-meta{font-size:11px;color:var(--text-tertiary)}.st-group-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.st-file-card{display:flex;flex-direction:column;background:var(--bg);border:1px solid var(--border);border-radius:8px;overflow:hidden;text-decoration:none;color:inherit;transition:var(--transition);cursor:pointer}.st-file-card:hover{border-color:var(--accent);box-shadow:var(--shadow);transform:translateY(-1px)}.st-file-preview{width:100%;height:100px;overflow:hidden;background:var(--surface-secondary);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:3px}.st-file-preview img{width:100%;height:100%;object-fit:cover}.st-file-preview-icon{background:linear-gradient(135deg,var(--surface-secondary) 0%,var(--bg) 100%)}.st-file-type-label{font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.st-file-details{padding:6px 8px 8px}.st-file-name{font-size:11px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:3px}.st-file-meta-row{display:flex;flex-wrap:wrap;gap:5px;align-items:center;font-size:10px;color:var(--text-tertiary)}.st-widget-name{max-width:80px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-style:italic}.st-file-size{white-space:nowrap}@media(max-width:600px){.st-summary-row{grid-template-columns:1fr 1fr 1fr;gap:6px}.st-summary-card{padding:10px}.st-summary-val{font-size:18px}.st-group-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:6px}.st-file-preview{height:80px}}.sp-page-header{margin-bottom:20px}.sp-page-title{font-size:22px;font-weight:700;display:flex;align-items:center;gap:8px;letter-spacing:-.4px}.sp-total-badge{background:var(--accent);color:#fff;font-size:13px;font-weight:700;padding:2px 9px;border-radius:10px;min-width:22px;text-align:center}.sp-layout{display:grid;grid-template-columns:340px 1fr;gap:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;height:calc(100dvh - 180px);min-height:500px;box-shadow:var(--shadow-md)}.sp-sidebar{border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.sp-search-wrap{padding:12px;border-bottom:1px solid var(--border)}.sp-search-input{width:100%;padding:9px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;background:var(--surface-secondary);outline:none;transition:border-color .15s;font-family:inherit}.sp-search-input:focus{border-color:var(--accent)}.sp-thread-list{flex:1;overflow-y:auto}.sp-empty{text-align:center;padding:48px 24px;color:var(--text-secondary);font-size:14px}.sp-thread-card{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;cursor:pointer;transition:background .1s;border-bottom:1px solid var(--surface-secondary)}.sp-thread-card:hover{background:var(--surface-secondary)}.sp-thread-card.active{background:var(--accent-light)}.sp-thread-avatar{width:40px;height:40px;border-radius:20px;background:var(--surface-secondary);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:600;color:var(--text-secondary);flex-shrink:0}.sp-thread-body{flex:1;min-width:0}.sp-thread-top{display:flex;justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:3px}.sp-thread-name{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sp-thread-time{font-size:12px;color:var(--text-tertiary);white-space:nowrap;flex-shrink:0}.sp-thread-bottom{display:flex;align-items:center;gap:8px}.sp-thread-preview{font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.sp-you{color:var(--text-tertiary)}.sp-unread-badge{background:var(--accent);color:#fff;font-size:11px;font-weight:700;padding:1px 7px;border-radius:8px;min-width:18px;text-align:center;flex-shrink:0}.sp-chat{display:flex;flex-direction:column;overflow:hidden}.sp-chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--text-secondary)}.sp-chat-empty-icon{font-size:48px;margin-bottom:8px}.sp-chat-empty h3{font-size:18px;font-weight:600;color:var(--text)}.sp-chat-empty p{font-size:14px}.sp-chat-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.sp-chat-header-info{display:flex;align-items:center;gap:10px}.sp-chat-header-info h3{font-size:16px;font-weight:600}.sp-status-pill{font-size:11px;font-weight:600;padding:2px 10px;border-radius:4px;text-transform:uppercase;letter-spacing:.3px}.sp-status-pill.open{background:var(--success-light);color:var(--success)}.sp-status-pill.closed{background:var(--surface-secondary);color:var(--text-tertiary)}.sp-messages{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column}.sp-messages-loading{flex:1;display:flex;align-items:center;justify-content:center}.sp-messages-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);font-size:14px}.sp-msg-time{text-align:center;font-size:11px;color:var(--text-tertiary);margin:14px 0 8px}.sp-msg-row{display:flex;margin-bottom:4px}.sp-msg-row.user{justify-content:flex-start}.sp-msg-row.admin{justify-content:flex-end}.sp-msg-bubble{max-width:70%;padding:10px 14px;border-radius:18px;font-size:14px;line-height:1.45;word-break:break-word}.sp-msg-bubble.user{background:var(--surface-secondary);color:var(--text);border-bottom-left-radius:6px}.sp-msg-bubble.admin{background:var(--accent);color:#fff;border-bottom-right-radius:6px}.sp-typing{display:flex;align-items:center;gap:4px;padding:12px 18px}.sp-typing-dot{width:7px;height:7px;border-radius:50%;background:var(--text-tertiary);animation:sp-bounce 1.2s infinite}.sp-typing-dot:nth-child(2){animation-delay:.2s}.sp-typing-dot:nth-child(3){animation-delay:.4s}@keyframes sp-bounce{0%,80%,to{opacity:.4;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.sp-input-bar{display:flex;align-items:flex-end;gap:10px;padding:12px 20px 16px;border-top:1px solid var(--border);flex-shrink:0}.sp-text-input{flex:1;padding:10px 14px;border:1px solid var(--border);border-radius:20px;font-size:14px;font-family:inherit;outline:none;resize:none;max-height:120px;min-height:40px;line-height:1.4;background:var(--surface-secondary);transition:border-color .15s}.sp-text-input:focus{border-color:var(--accent)}.sp-send-btn{border-radius:20px;padding:9px 20px;flex-shrink:0}.sp-msg-images{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:4px}.sp-msg-img{max-width:220px;max-height:180px;border-radius:10px;object-fit:cover;cursor:pointer;transition:opacity .15s}.sp-msg-img:hover{opacity:.85}.sp-msg-delivered{display:block;font-size:10px;color:var(--text-tertiary);text-align:right;margin-top:4px;opacity:.7}.sp-msg-bubble.admin .sp-msg-delivered{color:#ffffff8c}.sp-pending-bar{display:flex;gap:8px;padding:8px 20px;border-top:1px solid var(--border);flex-shrink:0}.sp-pending-thumb-wrap{position:relative}.sp-pending-thumb{width:52px;height:52px;border-radius:8px;object-fit:cover}.sp-pending-remove{position:absolute;top:-6px;right:-6px;width:20px;height:20px;border-radius:50%;background:var(--danger, #ef4444);color:#fff;border:none;font-size:14px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.sp-attach-btn{background:none;border:none;font-size:20px;cursor:pointer;padding:6px;border-radius:6px;transition:background .15s;flex-shrink:0}.sp-attach-btn:hover{background:var(--surface-secondary)}.sp-attach-btn:disabled{opacity:.4;cursor:default}.sp-chat-header-actions{display:flex;gap:6px;align-items:center}.sp-chat-header-actions .btn-ghost{border:1px solid var(--border)}.sp-chat-header-actions .btn-ghost:hover{background:var(--surface-secondary);border-color:var(--border-strong)}.sp-chat-with-notes{border-right:1px solid var(--border)}.sp-layout:has(.sp-notes-panel){grid-template-columns:320px 1fr 300px}.sp-notes-panel{display:flex;flex-direction:column;background:var(--surface);overflow:hidden}.sp-notes-header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 12px;border-bottom:1px solid var(--border);flex-shrink:0}.sp-notes-header h3{font-size:15px;font-weight:600;margin:0}.sp-notes-close{background:none;border:none;font-size:20px;cursor:pointer;color:var(--text-secondary);padding:2px 6px;border-radius:4px}.sp-notes-close:hover{background:var(--surface-secondary)}.sp-notes-input-wrap{padding:12px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.sp-notes-input{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-family:inherit;outline:none;resize:none;background:var(--surface-secondary);margin-bottom:8px}.sp-notes-input:focus{border-color:var(--accent)}.sp-notes-add-btn{width:100%}.sp-notes-list{flex:1;overflow-y:auto;padding:8px 16px 16px}.sp-note-card{padding:10px 12px;border:1px solid var(--border);border-radius:8px;margin-bottom:8px}.sp-note-body{font-size:13px;line-height:1.5;white-space:pre-wrap}.sp-note-meta{display:flex;justify-content:space-between;align-items:center;margin-top:8px;font-size:11px;color:var(--text-tertiary)}.sp-note-delete{background:none;border:none;color:var(--danger, #ef4444);font-size:11px;cursor:pointer;padding:2px 4px}.sp-note-delete:hover{text-decoration:underline}.sp-note-images{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.sp-note-img{max-width:120px;max-height:90px;border-radius:6px;object-fit:cover;cursor:pointer;border:1px solid var(--border)}.sp-note-img:hover{opacity:.85}.sp-note-pending-bar{display:flex;gap:6px;padding:6px 0;flex-wrap:wrap}.sp-note-pending-thumb-wrap{position:relative}.sp-note-pending-thumb{width:48px;height:48px;object-fit:cover;border-radius:6px;border:1px solid var(--border)}.sp-notes-actions{display:flex;align-items:center;gap:8px;justify-content:space-between}.sp-note-attach-btn{display:flex;align-items:center;gap:4px;font-size:12px}@media(max-width:768px){.sp-layout{grid-template-columns:1fr;height:auto}.sp-layout:has(.sp-notes-panel){grid-template-columns:1fr}.sp-sidebar{border-right:none;border-bottom:1px solid var(--border);max-height:300px}.sp-chat{min-height:400px}}@media(max-width:900px){.header{flex-wrap:wrap;height:auto;padding:8px 16px;gap:4px}.header-left{width:100%;justify-content:space-between;flex-wrap:wrap}.header-nav{margin-left:0;width:100%;order:3;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:0;border-top:1px solid var(--border);margin-top:4px;padding-top:2px}.header-nav::-webkit-scrollbar{display:none}.header-nav-item{font-size:12px;padding:8px 12px;flex-shrink:0}.container{padding:16px 12px 40px}.templates-grid{grid-template-columns:1fr}.u-stats-row{grid-template-columns:repeat(3,1fr)}.editor-layout,.ud-overview{grid-template-columns:1fr}}@media(max-width:480px){.u-stats-row{grid-template-columns:repeat(2,1fr)}.u-toolbar{flex-wrap:wrap}.u-search-wrap{max-width:100%}.uc-stats{display:none}}.fr-status-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:10px;font-size:12px;font-weight:600;white-space:nowrap}.fr-status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.fr-category-badge{display:inline-block;padding:2px 8px;border-radius:8px;font-size:11px;font-weight:500;background:var(--surface-secondary);color:var(--text-secondary);white-space:nowrap}.ge-container{position:relative;animation:fadeIn .15s ease}.ge-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px;flex-wrap:wrap}.ge-legend{display:flex;flex-wrap:wrap;gap:4px}.ge-legend-item{display:inline-flex;align-items:center;gap:5px;padding:4px 8px;background:var(--surface);border:1px solid var(--border);border-radius:6px;font-size:11px;cursor:pointer;transition:var(--transition);color:var(--text);font-family:inherit}.ge-legend-item:hover:not(:disabled){border-color:var(--accent)}.ge-legend-item.hidden{opacity:.4}.ge-legend-item:disabled{cursor:default}.ge-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.ge-legend-label{font-weight:500}.ge-legend-count{color:var(--text-tertiary);font-size:10px}.ge-stats{font-size:11px;color:var(--text-tertiary);flex-shrink:0}.ge-main{display:flex;gap:0;position:relative}.ge-canvas{flex:1;min-width:0;height:500px;border:1px solid var(--border);border-radius:10px;overflow:hidden;background:var(--surface);transition:border-radius .2s ease}.ge-has-panel .ge-canvas{border-top-right-radius:0;border-bottom-right-radius:0;border-right:none}.ge-detail{width:320px;flex-shrink:0;border:1px solid var(--border);border-top-right-radius:10px;border-bottom-right-radius:10px;background:var(--surface);display:flex;flex-direction:column;max-height:500px;animation:geSlideIn .2s ease}@keyframes geSlideIn{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.ge-detail-header{display:flex;align-items:flex-start;justify-content:space-between;padding:14px 16px 12px;border-bottom:1px solid var(--border);flex-shrink:0}.ge-detail-type{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.ge-detail-title{font-size:15px;font-weight:600;color:var(--text);word-break:break-word;line-height:1.3}.ge-detail-close{background:none;border:none;font-size:20px;color:var(--text-tertiary);cursor:pointer;padding:0 0 0 8px;line-height:1;flex-shrink:0;font-family:inherit}.ge-detail-close:hover{color:var(--text)}.ge-detail-body{overflow-y:auto;flex:1;padding:0}.ge-detail-fields{padding:12px 16px}.ge-detail-field{display:flex;flex-direction:column;gap:1px;padding:6px 0}.ge-detail-field+.ge-detail-field{border-top:1px solid var(--border)}.ge-df-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--text-tertiary)}.ge-df-value{font-size:13px;color:var(--text);word-break:break-word;display:flex;align-items:center;gap:6px}.ge-df-mono{font-family:SF Mono,Monaco,Consolas,monospace;font-size:11px;color:var(--text-secondary)}.ge-df-link{color:var(--accent);text-decoration:none;font-size:12px}.ge-df-link:hover{text-decoration:underline}.ge-df-color{width:12px;height:12px;border-radius:3px;flex-shrink:0;border:1px solid rgba(0,0,0,.08)}.ge-detail-connections{border-top:1px solid var(--border);padding:12px 16px 16px}.ge-detail-conn-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--text-tertiary);margin-bottom:10px}.ge-conn-group{margin-bottom:10px}.ge-conn-group:last-child{margin-bottom:0}.ge-conn-group-label{font-size:11px;font-weight:600;color:var(--text-secondary);display:flex;align-items:center;gap:6px;margin-bottom:4px}.ge-conn-list{display:flex;flex-direction:column;gap:1px}.ge-conn-item{display:flex;align-items:center;gap:6px;padding:4px 8px;border-radius:5px;cursor:pointer;border:none;background:none;font-family:inherit;font-size:12px;color:var(--text);text-align:left;transition:background .1s}.ge-conn-item:hover{background:var(--hover)}.ge-conn-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.ge-conn-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ge-conn-more{font-size:11px;color:var(--text-tertiary);padding:4px 8px}@media(max-width:768px){.ge-main{flex-direction:column}.ge-detail{width:100%;max-height:300px;border-radius:0 0 10px 10px;border-top:none;border-left:1px solid var(--border)}.ge-has-panel .ge-canvas{border-radius:10px 10px 0 0;border-right:1px solid var(--border);border-bottom:none}}@media(max-width:600px){.ge-canvas{height:380px}.ge-toolbar{flex-direction:column;align-items:flex-start}.ge-detail{max-height:260px}}
