@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@500&display=swap";@keyframes cube-spin{0%{transform:rotateX(-20deg)rotateY(0)}to{transform:rotateX(-20deg)rotateY(360deg)}}@keyframes cube-pulse{0%,to{opacity:1}50%{opacity:.65}}.cube-loader-wrap{flex:1;justify-content:center;align-items:center;min-height:60px;display:flex}.cube-scene{perspective:140px;width:32px;height:32px;animation:2s ease-in-out infinite cube-pulse}.cube{width:100%;height:100%;transform-style:preserve-3d;animation:1.4s linear infinite cube-spin;position:relative}.cube-face{border:2px solid var(--accent);background:var(--accent-light);border-radius:3px;width:32px;height:32px;position:absolute}.cube-front{transform:translateZ(16px)}.cube-back{transform:rotateY(180deg)translateZ(16px)}.cube-left{transform:rotateY(-90deg)translateZ(16px)}.cube-right{transform:rotateY(90deg)translateZ(16px)}.cube-top{transform:rotateX(90deg)translateZ(16px)}.cube-bottom{transform:rotateX(-90deg)translateZ(16px)}:root{--bg:#fff;--sidebar-bg:#1e293b;--canvas-bg:#f9fafb;--panel-bg:#fff;--text-primary:#1a1a1a;--text-secondary:#6b7280;--border:#e5e5e5;--accent:#0284c7;--accent-hover:#0369a1;--accent-light:#38bdf814;--accent-gradient:linear-gradient(135deg, #0369a1, #38bdf8);--success:#059669;--muted:#9ca3af;--navy:#475569;--navy-light:#64748b;--navy-subtle:#4755690f}*{box-sizing:border-box}body{background:var(--canvas-bg);color:var(--text-primary);margin:0;font-family:Inter,sans-serif;font-size:14px}a{color:var(--text-secondary);text-decoration:none}button,input,textarea,select{font:inherit}a,button,[role=button],[type=button],[type=submit]{cursor:pointer!important}button{border:1px solid var(--border);color:var(--text-primary);background:#fff;border-radius:6px;padding:8px 12px}button:hover{border-color:#d1d5db}input,textarea,select{border:1px solid var(--border);background:#fff;border-radius:6px;width:100%;margin-top:6px;padding:10px 12px}select{padding-right:8px}label{font-weight:500}.auth-page{background:#0a0a0f radial-gradient(circle,#ffffff0a 1px,#0000 1px) 0 0/24px 24px;place-items:center;min-height:100vh;padding:20px;display:grid;position:relative}.auth-page:before{content:"";pointer-events:none;background:radial-gradient(#38bdf81a 0%,#0596690d 40%,#0000 70%);width:600px;height:400px;position:absolute;top:20%;left:50%;transform:translate(-50%)}.auth-card{-webkit-backdrop-filter:blur(12px);z-index:1;background:#12121a99;border:1px solid #ffffff0f;border-radius:16px;gap:16px;width:min(420px,100%);padding:32px;display:grid;position:relative}.auth-card h1{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#38bdf8 0%,#7dd3fc 50%,#059669 100%);-webkit-background-clip:text;background-clip:text;margin:0 0 4px;font-size:26px;font-weight:700}.auth-card label{color:#8a8a9a;font-size:13px;font-weight:500}.auth-card input{color:#f0f0f5;background:#12121a;border:1px solid #ffffff0f;border-radius:8px;padding:10px 14px;font-size:14px;transition:border-color .2s}.auth-card input:focus{border-color:#38bdf8;outline:none}.auth-card button[type=submit]{color:#0a0a0f;cursor:pointer;background:#38bdf8;border:none;border-radius:10px;padding:12px;font-size:14px;font-weight:600;transition:background .15s;box-shadow:0 4px 14px #38bdf833}.auth-card button[type=submit]:hover{background:#7dd3fc}.auth-card button[type=submit]:disabled{opacity:.6;cursor:not-allowed}.auth-card p{color:#55556a;margin:0}.auth-card a{color:#38bdf8;text-decoration:none;transition:color .15s}.auth-card a:hover{color:#7dd3fc}.onboarding-page{background:var(--panel-bg);min-height:100vh}.onboarding-loading{min-height:100vh;color:var(--text-secondary);place-items:center;display:grid}.onboarding-split{grid-template-columns:1fr 1fr;min-height:100vh;display:grid}.onboarding-form-side{justify-content:center;align-items:center;padding:40px;display:flex}.onboarding-form-inner{flex-direction:column;gap:24px;width:min(440px,100%);display:flex}.onboarding-steps{gap:8px;display:flex}.onboarding-step-dot{background:var(--border);border-radius:2px;width:32px;height:4px;transition:background .2s}.onboarding-step-dot.active{background:#38bdf8}.onboarding-step-dot.done{background:#1e293b}.onboarding-step-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:500}.onboarding-content h1{color:var(--text-primary);margin:0;font-size:24px;font-weight:600}.onboarding-desc{color:var(--text-secondary);margin:6px 0 16px;font-size:14px;line-height:1.5}.onboarding-field{flex-direction:column;gap:6px;display:flex}.onboarding-field>span{color:var(--text-primary);font-size:13px;font-weight:500}.onboarding-field-label{color:var(--text-primary);margin-bottom:2px;font-size:13px;font-weight:500;display:block}.onboarding-invite-section{flex-direction:column;gap:8px;margin-top:8px;display:flex}.onboarding-invite-row{align-items:center;gap:8px;display:flex}.onboarding-invite-row input{flex:1}.onboarding-add-btn{color:#0284c7;cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;padding:4px 0;font-size:13px;font-weight:500;display:inline-flex}.onboarding-add-btn:hover{color:#0369a1}.onboarding-plan-card{border:1px solid var(--border);background:#f8fafc;border-radius:8px;padding:16px}.onboarding-plan-card h3{margin:0 0 10px;font-size:16px;font-weight:600}.onboarding-plan-card ul{color:var(--text-secondary);flex-direction:column;gap:6px;margin:0;padding:0 0 0 18px;font-size:14px;display:flex}.onboarding-plan-card li strong{color:var(--text-primary)}.onboarding-usage{flex-direction:column;gap:8px;margin-top:4px;display:flex}.onboarding-usage-row{color:var(--text-secondary);justify-content:space-between;font-size:13px;display:flex}.onboarding-plan-note{color:var(--text-secondary);margin:4px 0 0;font-size:13px}.onboarding-plan-link{color:#0284c7;cursor:pointer;font-weight:500}.onboarding-plan-link:hover{text-decoration:underline}.onboarding-actions{justify-content:space-between;align-items:center;margin-top:8px;display:flex}.onboarding-back-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:8px 0;font-size:14px;font-weight:500}.onboarding-back-btn:hover{color:var(--text-primary)}.onboarding-next-btn{color:#f1f5f9;cursor:pointer;background:#1e293b;border:none;border-radius:8px;padding:10px 28px;font-size:14px;font-weight:500;transition:background .15s}.onboarding-next-btn:hover{background:#334155}.onboarding-next-btn:disabled{opacity:.5;cursor:not-allowed}.onboarding-visual-side{background:#1e293b;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.onboarding-visual-inner{z-index:1;width:min(320px,80%);position:relative}.onboarding-visual-bg{z-index:0;background-image:radial-gradient(circle at 20% 30%,#38bdf814 0%,#0000 50%),radial-gradient(circle at 80% 70%,#38bdf80f 0%,#0000 50%),radial-gradient(circle at 1px 1px,#ffffff08 1px,#0000 0);background-size:100% 100%,100% 100%,20px 20px;position:absolute;inset:0}.onboarding-visual-card{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff0f;border:1px solid #ffffff14;border-radius:12px;padding:24px}.onboarding-visual-icon{color:#38bdf8}.onboarding-time-display{align-items:center;gap:10px;margin-bottom:8px;display:flex}.onboarding-time-value{color:#f1f5f9;letter-spacing:-.02em;font-size:36px;font-weight:600}.onboarding-time-date{color:#94a3b8;margin:0 0 16px;font-size:14px}.onboarding-tz-badge{color:#38bdf8;background:#38bdf81a;border:1px solid #38bdf833;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;display:inline-flex}.onboarding-team-visual{align-items:center;gap:10px;margin-bottom:16px;display:flex}.onboarding-team-visual h3{color:#f1f5f9;margin:0;font-size:18px;font-weight:600}.onboarding-member-list{flex-direction:column;gap:10px;display:flex}.onboarding-member-row{align-items:center;gap:10px;display:flex}.onboarding-avatar{color:#38bdf8;background:#38bdf826;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:600;display:flex}.onboarding-avatar-pending{color:#64748b;background:#ffffff0f}.onboarding-member-name{color:#f1f5f9;margin:0;font-size:14px;font-weight:500}.onboarding-member-email{color:#64748b;margin:2px 0 0;font-size:12px}.onboarding-member-pending{opacity:.7}.onboarding-plan-visual{align-items:center;gap:10px;margin-bottom:20px;display:flex}.onboarding-plan-visual h3{color:#f1f5f9;margin:0;font-size:18px;font-weight:600}.onboarding-plan-bars{flex-direction:column;gap:16px;display:flex}.onboarding-plan-bar-group{flex-direction:column;gap:6px;display:flex}.onboarding-plan-bar-label{color:#94a3b8;justify-content:space-between;font-size:13px;display:flex}.onboarding-plan-bar-track{background:#ffffff14;border-radius:3px;height:6px;overflow:hidden}.onboarding-plan-bar-fill{background:#38bdf8;border-radius:3px;min-width:2px;height:100%;transition:width .3s}.onboarding-calc-input{text-align:right;color:#fff;-moz-appearance:textfield;background:#ffffff0f;border:1px solid #ffffff14;border-radius:6px;width:64px;padding:4px 8px;font-size:13px;font-weight:500}.onboarding-calc-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.onboarding-calc-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.onboarding-calc-input:focus{border-color:#38bdf8;outline:none}@media (width<=768px){.onboarding-split{grid-template-columns:1fr}.onboarding-visual-side{display:none}.onboarding-form-side{padding:24px}}.pricing-page{background:var(--panel-bg);max-width:1100px;min-height:100vh;margin:0 auto;padding:24px 40px 60px}.pricing-header{margin-bottom:24px}.pricing-back-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:6px 0;font-size:14px;font-weight:500;display:inline-flex}.pricing-back-btn:hover{color:var(--text-primary)}.pricing-hero{text-align:center;margin-bottom:36px}.pricing-hero h1{color:var(--text-primary);margin:0;font-size:28px;font-weight:700}.pricing-hero p{color:var(--text-secondary);margin:8px 0 24px;font-size:15px}.pricing-toggle{background:#f1f5f9;border-radius:8px;gap:2px;padding:3px;display:inline-flex}.pricing-toggle button{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:6px;padding:8px 18px;font-size:13px;font-weight:500;transition:background .15s,color .15s;display:inline-flex}.pricing-toggle button.active{color:var(--text-primary);background:#fff;box-shadow:0 1px 3px #00000014}.pricing-save-badge{color:#0284c7;background:#38bdf81f;border-radius:4px;padding:2px 6px;font-size:11px;font-weight:600}.pricing-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:40px;display:grid}.pricing-card{border:1px solid var(--border);background:#fff;border-radius:10px;flex-direction:column;padding:24px 20px;display:flex;position:relative}.pricing-card-popular{border-color:#38bdf8;box-shadow:0 0 0 1px #38bdf8}.pricing-card-current{border-color:#1e293b}.pricing-popular-badge{color:#f1f5f9;white-space:nowrap;background:#1e293b;border-radius:10px;padding:3px 12px;font-size:11px;font-weight:600;position:absolute;top:-10px;left:50%;transform:translate(-50%)}.pricing-current-badge{color:#fff;white-space:nowrap;background:#38bdf8;border-radius:10px;padding:3px 12px;font-size:11px;font-weight:600;position:absolute;top:-10px;left:50%;transform:translate(-50%)}.pricing-card h3{margin:4px 0 12px;font-size:18px;font-weight:600}.pricing-price{align-items:baseline;gap:4px;margin-bottom:16px;display:flex}.pricing-amount{color:var(--text-primary);font-size:32px;font-weight:700}.pricing-period{color:var(--text-secondary);font-size:14px}.pricing-features{flex-direction:column;flex:1;gap:8px;margin:0 0 20px;padding:0;list-style:none;display:flex}.pricing-features li{color:var(--text-secondary);align-items:center;gap:8px;font-size:13px;display:flex}.pricing-features li svg{color:#38bdf8;flex-shrink:0}.pricing-btn{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:8px;width:100%;padding:10px;font-size:14px;font-weight:500;transition:background .15s}.pricing-btn:hover:not(:disabled){background:#f8fafc}.pricing-btn:disabled{opacity:.6;cursor:not-allowed}.pricing-btn-current{color:#f1f5f9;background:#1e293b;border-color:#1e293b}.pricing-redeem{text-align:center;margin-bottom:32px}.pricing-redeem h3{margin:0 0 12px;font-size:16px;font-weight:600}.pricing-redeem-form{align-items:center;gap:8px;display:inline-flex}.pricing-redeem-form input{text-align:center;letter-spacing:.1em;text-transform:uppercase;width:200px}.pricing-redeem-btn{color:#0284c7;cursor:pointer;background:#fff;border:1px solid #38bdf8;border-radius:8px;padding:9px 20px;font-size:14px;font-weight:500}.pricing-redeem-btn:hover:not(:disabled){background:#38bdf814}.pricing-redeem-btn:disabled{opacity:.5;cursor:not-allowed}.pricing-continue{text-align:center;padding-top:16px}.pricing-calculator{border:1px solid var(--border);background:#fff;border-radius:10px;margin-bottom:40px;padding:24px}.pricing-calculator h3{margin:0 0 4px;font-size:18px;font-weight:600}.pricing-calculator-desc{color:var(--text-secondary);margin:0 0 20px;font-size:13px}.pricing-calculator-grid{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px;display:grid}.pricing-calculator-field{flex-direction:column;gap:4px;display:flex}.pricing-calculator-field span{color:var(--text-primary);font-size:13px;font-weight:500}.pricing-calculator-field input{-moz-appearance:textfield}.pricing-calculator-field input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.pricing-calculator-field input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.pricing-calculator-result{border-top:1px solid var(--border);flex-direction:column;gap:10px;padding-top:16px;display:flex}.pricing-calculator-result-row{justify-content:space-between;align-items:center;font-size:14px;display:flex}.pricing-calculator-result-row>span:first-child{color:var(--text-secondary)}.pricing-calculator-value{color:#0284c7;font-size:18px;font-weight:600}.pricing-calculator-plan{color:var(--text-primary);background:#38bdf814;border-radius:6px;padding:4px 12px;font-weight:600}@media (width<=900px){.pricing-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=560px){.pricing-page{padding:20px}.pricing-grid{grid-template-columns:1fr}}.app-shell{grid-template-columns:240px 1fr;min-height:100vh;display:grid}.app-shell-fullscreen{grid-template-columns:1fr}.fullscreen-exit-btn{z-index:50;border:1px solid var(--border);background:var(--panel-bg);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;opacity:.6;border-radius:8px;justify-content:center;align-items:center;transition:opacity .15s;display:flex;position:fixed;top:12px;right:12px;box-shadow:0 1px 3px #00000014}.fullscreen-exit-btn:hover{opacity:1;color:var(--text-primary)}.sidebar{background:var(--sidebar-bg);border-right:none;flex-direction:column;justify-content:space-between;padding:18px;display:flex}.brand-block{margin-bottom:18px}.brand-logo{width:78%;max-width:180px;height:auto;margin:0 auto 4px;display:block}.brand-title{color:#f1f5f9;-webkit-text-fill-color:unset;background:0 0;margin:0;font-weight:600}.brand-subtitle{color:#94a3b8;margin:4px 0 0}.nav-list{gap:6px;display:grid}.nav-item{color:#cbd5e1;border-left:2px solid #0000;border-radius:8px;align-items:center;gap:8px;padding:10px;display:flex}.nav-item:hover{color:#f1f5f9;background:#ffffff12}.nav-item-active{color:#f1f5f9;background:#ffffff1a;border-left-color:#38bdf8}.nav-item-active svg{stroke:#38bdf8}.user-card{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;gap:8px;padding:12px;display:grid}.user-name{color:#f1f5f9;margin:0;font-weight:600}.user-email{color:#94a3b8;overflow-wrap:anywhere;margin:2px 0 0}.ghost-button{background:0 0;align-items:center;gap:8px;width:fit-content;display:inline-flex}.content-shell{grid-template-rows:auto 1fr;display:grid}.topbar{border-bottom:1px solid var(--border);background:#fff;padding:16px 22px}.topbar-title-row{justify-content:space-between;align-items:center;gap:10px;display:flex}.topbar-title-group{align-items:center;min-width:0;display:flex}.topbar-actions{flex-shrink:0;align-items:center;gap:8px;display:inline-flex}.topbar-action-btn{border:1px solid var(--border);color:var(--text-primary);background:#fff;border-radius:8px;align-items:center;padding:7px 12px;font-size:13px;font-weight:500;transition:background .15s,box-shadow .15s;display:inline-flex}.topbar-action-btn:hover{background:#f5f5f5;box-shadow:0 1px 3px #0000000f}.topbar-action-btn-primary{color:#0284c7;border-color:#38bdf8}.topbar-action-btn-primary:hover{background:#38bdf814;box-shadow:0 1px 3px #38bdf833}.menu-button{display:none}.topbar h1{color:var(--text-secondary);margin:0;font-size:18px}.topbar-dashboard-name-input{width:min(440px,58vw);color:var(--text-primary);background:0 0;border:none;border-radius:0;margin:0;padding:0;font-size:18px;font-weight:600}.topbar-dashboard-name-input:focus{outline:none}.topbar-dashboard-name-input::placeholder{color:var(--text-secondary)}.topbar-title-editable{border:1px solid #0000;border-radius:8px;align-items:center;gap:6px;padding:2px 8px;display:inline-flex}.topbar-title-editable:focus-within{border-color:var(--border);background:#f8fafc}.topbar-title-editable svg{color:var(--text-secondary);flex-shrink:0}.crumb{color:var(--text-secondary);margin:0}.page-shell{padding:22px}.page-shell-dashboard-detail{padding:0;overflow:hidden}.page-card{border:1px solid var(--border);background:#fff;border-radius:8px;padding:18px}.reports-page{gap:18px;display:grid}.reports-tabs{border-bottom:1px solid var(--border);align-items:flex-end;gap:2px;margin-bottom:4px;display:inline-flex}.reports-tab{color:var(--text-secondary);background:0 0;border:1px solid #0000;border-bottom:none;border-radius:8px 8px 0 0;margin-bottom:-1px;padding:8px 14px}.reports-tab:hover{color:var(--text-primary);background:#f7f9fb}.reports-tab-active{color:var(--text-primary);border-color:var(--border);background:#fff;font-weight:600}.reports-tab-panel{gap:12px;display:grid}.reports-section{gap:14px;display:grid}.reports-section-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.reports-section-header h2{margin:0}.reports-section-header p{margin:6px 0 0}.reports-modal-card{width:min(760px,100%)}.slideout-backdrop{z-index:120;background:#00000038;justify-content:flex-end;animation:.22s slideout-backdrop-in;display:flex;position:fixed;inset:0}.slideout-panel{border-left:1px solid var(--border);will-change:transform, opacity;background:#fff;width:min(680px,100vw);height:100vh;padding:18px;animation:.3s cubic-bezier(.2,.8,.2,1) slideout-panel-in;overflow-y:auto;transform:translate(0);box-shadow:-20px 0 30px #0f172a1f}.reports-slideout-panel{width:min(760px,100vw)}@keyframes slideout-backdrop-in{0%{background:0 0}to{background:#00000038}}@keyframes slideout-panel-in{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.reports-field-label{margin:0 0 8px;font-weight:500}.reports-form-section{margin-top:10px}.reports-sources-section{border:1px solid var(--border);background:#fbfcff;border-radius:10px;padding:12px}.reports-recipients-section{border-top:1px solid var(--border);padding-top:12px}.reports-time-grid,.cadence-picker-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.datasource-list{gap:10px;display:grid}.datasource-row{grid-template-columns:minmax(0,1.2fr) minmax(0,1fr) minmax(0,1fr) auto;align-items:end;gap:10px;display:grid}.datasource-add-btn,.datasource-remove-btn{align-self:end}.recipient-editor-row{grid-template-columns:minmax(0,1fr) auto;gap:10px;display:grid}.recipient-add-btn{align-self:start;height:40px;margin-top:6px}.recipient-chip-list{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.recipient-chip{color:var(--text-primary);background:#f3f4f6;border-radius:999px;align-items:center;gap:8px;padding:6px 10px;display:inline-flex}.recipient-chip button{color:var(--text-secondary);background:0 0;border:none;padding:0}.reports-toggle-row{align-items:center;gap:10px;width:fit-content;display:inline-flex}.reports-toggle-row input{width:auto;margin:0}.schedule-group-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.schedule-pair-group{border:1px solid var(--border);background:#fbfcff;border-radius:10px;gap:10px;padding:12px;display:grid}.schedule-group-title{color:var(--text-secondary);letter-spacing:.03em;text-transform:uppercase;margin:0;font-size:12px;font-weight:600}.reports-sources-section .schedule-group-title{margin-bottom:8px}.schedule-pair-row{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:10px;display:grid}.status-badge{border-radius:999px;align-items:center;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.status-done{color:#047857;background:#10b98124}.status-running{color:#047857;background:#10b9811f}.status-error{color:#b91c1c;background:#ef444424}.status-pending{color:#4b5563;background:#9ca3af2e}.reports-run-name-cell{align-items:center;gap:8px;display:flex}.reports-run-meta{color:var(--text-secondary);text-transform:capitalize}.reports-error-text{color:#b91c1c;margin:6px 0 0;font-size:12px}.page-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.page-header h2,.page-header h3{color:var(--navy);margin:0;font-weight:400}.data-table{border-collapse:collapse;width:100%}.data-table th{border-bottom:1px solid var(--border);text-align:left;color:var(--navy);text-transform:uppercase;letter-spacing:.04em;padding:10px;font-size:12px}.data-table td{border-bottom:1px solid var(--border);text-align:left;padding:10px}.clickable-row{cursor:pointer}.clickable-row:hover{background:#fafafa}.dot{border-radius:999px;width:8px;height:8px;margin-right:8px;display:inline-block}.dot-online{background:var(--success)}.dot-offline{background:var(--muted)}.modal-backdrop{background:#00000038;place-items:center;padding:16px;display:grid;position:fixed;inset:0}.modal-card{border:1px solid var(--border);background:#fff;border-radius:8px;width:min(560px,100%);padding:18px}.invite-modal-card{width:min(520px,100%)}.modal-close-icon{width:28px;height:28px;color:var(--text-secondary);box-shadow:none;background:0 0;border:none;border-radius:999px;outline:none;justify-content:center;align-items:center;padding:2px;display:inline-flex}.modal-close-icon:hover{color:var(--text-primary);background:#f3f4f6}.row-actions-menu-anchor{display:inline-flex;position:relative}.row-actions-trigger{background:0 0;border-color:#0000}.row-actions-trigger:hover{background:#f3f4f6}.row-actions-menu{z-index:30;border:1px solid var(--border);background:#fff;border-radius:8px;flex-direction:column;min-width:130px;padding:6px;display:flex;position:absolute;top:calc(100% + 4px);right:0;box-shadow:0 4px 16px #0000001f}.row-actions-item{text-align:left;background:0 0;border:none;border-radius:6px;padding:8px 10px}.row-actions-item:hover{background:#f3f4f6}.row-actions-item-danger{color:#ef4444}.row-actions-item-danger:hover{background:#fff1f0}.form-stack{gap:12px;display:grid}.invite-form{margin-top:2px}.invite-field{width:100%}.invite-actions{justify-content:flex-end;margin-top:6px;display:flex}.invite-submit-btn{border-color:var(--accent);min-width:112px;color:var(--accent);background:#fff;padding:6px 12px}.invite-submit-btn:hover{background:var(--accent-light);box-shadow:0 2px 8px #10b98126}.invite-submit-btn:disabled{opacity:.7;cursor:not-allowed}.credentials-card{border:1px solid var(--border);border-radius:8px;flex-direction:column;align-items:flex-start;gap:10px;margin-top:14px;padding:12px;display:flex}.credentials-card h4{margin:0}.settings-tabs{border-bottom:1px solid var(--border);align-items:flex-end;gap:2px;margin-bottom:8px;display:inline-flex}.settings-tab{color:var(--text-secondary);background:0 0;border:1px solid #0000;border-bottom:none;border-radius:8px 8px 0 0;margin-bottom:-1px;padding:8px 14px}.settings-tab:hover{color:var(--text-primary);background:#f7f9fb}.settings-tab-active{color:var(--text-primary);border-color:var(--border);background:#fff;font-weight:600}.settings-panel{min-height:220px}.settings-general-panel{flex-direction:column;display:flex}.settings-inline-field{align-items:center;gap:12px;display:flex}.settings-inline-field>span{padding-right:8px}.settings-inline-field .settings-team-name-input{margin-top:0}.settings-team-name-input{max-width:380px}.settings-actions{justify-content:flex-end;margin-top:auto;display:flex}.settings-actions-left{justify-content:flex-start;margin-top:0}.settings-divider{border:0;border-top:1px solid var(--border);width:100%;margin:4px 0 0}.settings-save-btn{border-radius:6px;padding:6px 12px;font-size:13px}.settings-logout-btn{color:#ef4444;background:#fff;border-color:#ef4444;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;display:inline-flex}.settings-logout-btn:hover{background:#fff1f0}.api-key-created-banner{border:1px solid var(--border);background:var(--accent-light);border-radius:8px;padding:12px 16px}.api-key-display{align-items:center;gap:8px;display:flex}.api-key-value{overflow-wrap:anywhere;flex:1;font-family:JetBrains Mono,monospace;font-size:13px}.token-row{border:1px solid var(--border);border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex}.token-label{color:var(--text-secondary);margin:0}.token-value{overflow-wrap:anywhere;margin:4px 0 0;font-family:JetBrains Mono,monospace;font-size:12px}.token-actions{gap:6px;display:inline-flex}.icon-button{justify-content:center;align-items:center;width:32px;height:32px;padding:0;display:inline-flex}.detail-grid{gap:16px;display:grid}.status-row{align-items:center;display:inline-flex}.muted-text{color:var(--text-secondary)}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:48px 24px;display:flex}.empty-state-icon{color:var(--navy-light);opacity:.5;margin-bottom:12px}.empty-state-title{color:var(--navy);margin:0;font-size:16px;font-weight:500}.empty-state-desc{color:var(--text-secondary);max-width:320px;margin:6px 0 0;font-size:13px}.empty-state-action{margin-top:16px;font-size:13px;font-weight:500;background:var(--accent)!important;color:#fff!important;border:none!important;padding:8px 16px!important}.empty-state-action:hover{background:var(--accent-hover)!important}.dashboard-view-shell{height:100%;position:relative}.dashboard-canvas-card{background:var(--canvas-bg);border:none;border-radius:0;height:100%;padding:12px}.dashboard-canvas-edit{background-color:#f8fafc;background-image:radial-gradient(circle at 1px 1px,#3b82f624 1px,#0000 0),linear-gradient(135deg,#3b82f60f 25%,#0000 25% 50%,#3b82f60f 50% 75%,#0000 75%,#0000);background-size:16px 16px,24px 24px}.dashboard-toolbar{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.dashboard-toolbar-actions{gap:10px;display:inline-flex}.dashboard-title-input{background:#fff;max-width:420px;margin-top:0;font-size:18px;font-weight:600}.dashboards-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;display:grid}.dashboard-card-link{color:inherit}.dashboard-card{border:1px solid var(--border);background:#fff;border-radius:8px;gap:6px;padding:14px;display:grid}.dashboard-card h3,.dashboard-card p,.dashboard-card small{margin:0}.widget-type-inline{align-items:center;gap:6px;display:inline-flex}.react-grid-item{overflow:visible!important}.widget-card{border:1px solid var(--border);background:#fff;border-radius:8px;flex-direction:column;height:100%;padding:10px;display:flex;overflow:visible}.widget-card-edit{border-style:dashed;border-color:var(--accent)}.widget-header{justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;display:flex;position:relative}.widget-menu-anchor{position:relative}.widget-header h4{margin:0;font-size:13px}.widget-body{flex:1;min-height:0;container-type:size}.widget-error{color:#ef4444}.number-widget{text-align:center;place-content:center;justify-items:center;gap:6px;height:100%;display:grid}.number-widget p{margin:0;font-size:clamp(18px,11cqw,80px);font-weight:600;transition:color .2s}.number-widget small{font-size:clamp(10px,3cqw,14px)}.gauge-widget{flex-direction:column;justify-content:center;align-items:stretch;gap:2px;width:100%;height:100%;display:flex}.gauge-chart-wrap{flex:1;width:min(700px,100%);max-width:100%;min-height:80px;margin:0 auto;position:relative}.gauge-chart-wrap canvas{width:100%!important;height:100%!important}.gauge-overlay{text-align:center;pointer-events:none;position:absolute;top:73%;left:50%;transform:translate(-50%,-50%)}.gauge-value{margin:0;font-size:clamp(18px,12cqw,60px);font-weight:600;line-height:1}.gauge-overlay .muted-text{font-size:13px}.gauge-scale{justify-content:space-between;font-size:12px;display:flex;position:absolute;bottom:9%;left:14%;right:14%}.cylinder-widget{flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:0 12px;display:flex}.cylinder-body{width:clamp(60px,35cqw,220px);height:clamp(80px,75cqh,360px);position:relative}.cylinder-scale{flex-direction:column;justify-content:space-between;align-items:center;min-width:16px;font-size:12px;display:flex;position:absolute;top:0;bottom:0;right:calc(100% + 15px)}.cylinder-shell{background:#f8fafc;border:2px solid #d1d5db;border-radius:18px/42px;width:100%;height:100%;position:relative;overflow:hidden}.cylinder-track{background:linear-gradient(#f8fafc 0%,#f1f5f9 100%);position:absolute;inset:0}.cylinder-fill{background:linear-gradient(#34d399 0%,#059669 100%);transition:height .2s;position:absolute;bottom:0;left:0;right:0}.cylinder-gloss{pointer-events:none;background:#ffffff47;border-radius:999px;width:14%;height:86%;position:absolute;top:7%;left:14%}.cylinder-value{margin:0;font-size:clamp(14px,10cqw,44px);font-weight:600;line-height:1}.cylinder-readout{white-space:nowrap;flex-direction:column;align-items:flex-start;gap:0;display:flex;position:absolute;top:50%;left:calc(100% + 15px);transform:translateY(-50%)}.cylinder-label{margin:-2px 0 0;font-size:13px;line-height:1}.cylinder-widget>small:last-child{margin-top:6px}.value-warning{color:#f59e0b}.value-critical{color:#ef4444}.chart-widget{flex-direction:column;height:100%;min-height:0;display:flex;overflow:visible}.chart-canvas-wrap{flex:1;min-height:0;position:relative}.chart-header-row{justify-content:flex-end;align-items:center;gap:10px;margin-bottom:10px;display:flex}.chart-range-control{align-items:center;gap:8px;font-weight:500;display:inline-flex}.chart-range-control span{color:var(--text-secondary);letter-spacing:.04em;text-transform:uppercase;font-size:12px}.chart-range-control select{width:auto;min-width:88px;margin-top:0;padding:6px 10px}.chart-options-wrap{position:relative}.chart-options-btn{border:1px solid var(--border);width:34px;height:34px;color:var(--text-secondary);background:#fff;border-radius:6px;justify-content:center;align-items:center;padding:0;display:inline-flex}.chart-options-btn:hover{color:var(--text-primary)}.chart-options-panel{border:1px solid var(--border);z-index:50;z-index:10;background:#fff;border-radius:8px;flex-direction:column;gap:8px;min-width:220px;margin-top:4px;padding:10px;display:flex;position:absolute;top:100%;right:0;box-shadow:0 4px 12px #00000014}.chart-options-panel .chart-range-control{justify-content:space-between;width:100%;display:flex}.range-picker{position:relative}.range-picker-trigger{white-space:nowrap;align-items:center;gap:6px;font-size:13px;font-weight:500;display:inline-flex;padding:6px 10px!important}.range-picker-label{text-overflow:ellipsis;max-width:280px;overflow:hidden}.range-picker-dropdown{border:1px solid var(--border);z-index:50;background:#fff;border-radius:8px;width:240px;margin-top:4px;padding:6px;position:absolute;top:100%;right:0;box-shadow:0 4px 12px #00000014}.range-picker-section-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;padding:4px 8px 2px;font-size:11px;font-weight:600}.range-picker-presets{grid-template-columns:1fr 1fr;gap:2px;display:grid}.range-picker-option{text-align:left;width:100%;color:var(--text-primary);border-radius:4px;font-size:13px;display:block;background:0 0!important;border:none!important;padding:6px 8px!important}.range-picker-option:hover{background:var(--bg-hover)!important}.range-picker-option.active{color:var(--accent);font-weight:500;background:var(--accent-light)!important}.range-picker-divider{background:var(--border);height:1px;margin:4px 0}.range-picker-abs-toggle{text-align:left;width:100%;color:var(--text-primary);border-radius:4px;align-items:center;gap:6px;font-size:13px;display:flex;background:0 0!important;border:none!important;padding:6px 8px!important}.range-picker-abs-toggle:hover{background:var(--bg-hover)!important}.range-picker-abs-toggle.active{color:var(--accent);font-weight:500;background:var(--accent-light)!important}.range-picker-abs-form{border-top:1px solid var(--border);flex-direction:column;gap:8px;margin-top:4px;padding:8px;display:flex}.range-picker-abs-label{color:var(--text-secondary);flex-direction:column;gap:4px;font-size:12px;font-weight:500;display:flex}.range-picker-abs-label input{margin-top:0;padding:6px 8px;font-size:13px}.range-picker-abs-apply{border-radius:6px;margin-top:2px;font-size:13px;font-weight:500;background:var(--accent)!important;color:#fff!important;border:none!important;padding:6px 12px!important}.range-picker-abs-apply:hover{background:var(--accent-hover)!important}.chart-agg-warning{color:#b45309;background:#fffbeb;border:1px solid #fde68a;border-radius:6px;margin-bottom:8px;padding:6px 10px;font-size:12px}.widget-type-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.widget-type-card{justify-content:center;align-items:center;gap:8px;padding:12px;display:flex}.widget-type-card.selected{border-color:var(--accent);background:#ecfdf5}.modal-footer{justify-content:flex-end;gap:8px;margin-top:14px;display:flex}.report-primary-btn{border-color:var(--accent);color:var(--accent);background:#fff}.report-primary-btn:hover{background:var(--accent-light);box-shadow:0 2px 8px #10b98126}.report-primary-btn:disabled{opacity:.7;cursor:not-allowed}.source-row{border:1px solid var(--border);border-radius:8px;gap:8px;padding:10px;display:grid}.widget-action-menu{z-index:50;border:1px solid var(--border);background:#fff;border-radius:8px;flex-direction:column;min-width:150px;padding:6px;display:flex;position:absolute;top:calc(100% + 4px);right:0;box-shadow:0 4px 16px #0000001f}.widget-action-menu-title{color:var(--text-secondary);border-bottom:1px solid var(--border);margin:0 0 4px;padding:6px 10px 8px;font-size:12px;font-weight:600}.widget-action-confirm-text{color:var(--text-secondary);margin:0;padding:6px 10px 8px;font-size:13px}.widget-action-item{text-align:left;cursor:pointer;width:100%;color:var(--text-primary);background:0 0;border:none;border-radius:5px;padding:8px 10px;font-size:14px;display:block}.widget-action-item:hover{background:#f4f6f8}.widget-action-item-danger{color:#ef4444}.widget-action-item-danger:hover{background:#fff1f0}.danger-button{color:#ef4444;border-color:#ef4444}.builder-overlay{z-index:50;background:var(--bg);flex-direction:column;display:flex;position:fixed;inset:0;overflow:hidden}.builder-header{border-bottom:1px solid var(--border);background:#fff;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:14px 24px;display:flex}.builder-header-left{align-items:center;gap:12px;display:flex}.builder-title{font-size:16px;font-weight:600}.builder-step-indicator{color:var(--text-secondary);font-size:13px}.builder-mode-toggle{gap:6px;display:inline-flex}.builder-body{flex:1;width:100%;max-width:680px;margin:0 auto;padding:32px 24px;overflow-y:auto}.builder-step-title{margin:0 0 4px;font-size:18px;font-weight:600}.builder-footer{border-top:1px solid var(--border);background:#fff;flex-shrink:0;justify-content:flex-end;gap:8px;padding:14px 24px;display:flex}.builder-dashboard-list{gap:8px;margin-top:8px;display:grid}.builder-dashboard-check{border:1px solid var(--border);cursor:pointer;border-radius:6px;align-items:center;gap:8px;padding:10px 12px;font-weight:400;display:flex}.builder-dashboard-check:hover{border-color:var(--accent)}.builder-widget-list{gap:8px;display:grid}.builder-widget-item{border:1px solid var(--border);text-align:left;cursor:pointer;background:#fff;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;width:100%;padding:12px 14px;display:flex}.builder-widget-item:hover:not(.disabled){border-color:var(--accent)}.builder-widget-item.selected{border-color:var(--accent);background:#ecfdf5}.builder-widget-item.disabled{opacity:.5;cursor:not-allowed}.builder-widget-item-details{flex-direction:column;gap:2px;display:flex}.builder-widget-item-dashboards{flex-wrap:wrap;gap:4px;display:flex}.dashboard-tag{border:1px solid var(--border);color:var(--text-secondary);background:#f3f4f6;border-radius:4px;padding:2px 6px;font-size:11px;font-weight:500}.tag-current{border-color:var(--accent);color:var(--accent);background:#ecfdf5}.editor-loading{color:var(--text-secondary);padding:40px;font-size:14px}.editor-page{flex-direction:column;height:calc(100vh - 52px);margin:-22px;display:flex;overflow:hidden}.editor-topbar{flex-shrink:0;align-items:center;gap:12px;height:60px;padding:0 22px;display:flex}.editor-topbar-left{flex:1;align-items:center;gap:8px;min-width:0;display:flex;overflow:hidden}.editor-breadcrumbs{color:var(--text-secondary);white-space:nowrap;flex-shrink:0;align-items:center;gap:5px;font-size:13px;display:inline-flex}.editor-breadcrumbs a{color:var(--text-secondary);text-decoration:none}.editor-breadcrumbs a:hover{color:var(--text-primary)}.editor-breadcrumbs span{color:var(--text-secondary)}.editor-breadcrumb-name{border:1px solid #0000;border-radius:6px;align-items:center;gap:6px;min-width:120px;max-width:360px;padding:2px 6px;display:inline-flex}.editor-breadcrumb-name:focus-within{border-color:var(--border);background:#f8fafc}.editor-breadcrumb-name svg{color:var(--text-secondary);flex-shrink:0}.editor-breadcrumb-input{width:100%;min-width:90px;color:var(--text-primary);background:0 0;border:none;margin:0;padding:0;font-size:13px;font-weight:600}.editor-breadcrumb-input:focus{outline:none}.editor-breadcrumb-input::placeholder{color:var(--text-secondary);font-weight:400}.editor-topbar-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.editor-pill{border:1px solid var(--border);color:var(--text-primary);cursor:pointer;white-space:nowrap;background:#fff;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;transition:border-color .15s,background .15s;display:inline-flex}.editor-pill:hover,.editor-pill.active{border-color:var(--accent);background:#f5f8ff}.editor-save-btn{border-color:var(--accent);color:var(--accent);background:#fff;padding:7px 18px;font-size:13px}.editor-save-btn:hover{background:var(--accent-light)}.editor-body{flex:1;display:flex;overflow:hidden}.editor-options{border-right:1px solid var(--border);background:#fafafa;flex:0 0 38%;min-width:300px;max-width:460px;padding:16px 0;overflow-y:auto}.editor-section{padding:6px 20px}.editor-section+.editor-section{margin-top:4px}.editor-section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);margin-bottom:6px;font-size:11px;font-weight:600;display:block}.editor-section-hint{color:var(--text-secondary);margin:4px 0 0;font-size:11px}.editor-section-hint code{background:#0000000a;border-radius:3px;padding:1px 4px;font-size:11px}.editor-preview{background:#fff;flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.preview-range-bar{border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:4px;padding:12px 20px;display:flex}.preview-canvas{flex-direction:column;flex:1;min-width:0;padding:20px;display:flex;overflow:auto}.preview-hint{color:var(--text-secondary);text-align:center;margin:auto;font-size:14px}.type-toggle{border:1px solid var(--border);background:#fff;border-radius:8px;display:inline-flex;overflow:hidden}.type-tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:0;padding:6px 14px;font-size:13px;font-weight:500;transition:background .12s,color .12s}.type-tab:first-child{border-right:1px solid var(--border)}.type-tab.active{background:var(--accent);color:#fff}.type-tab:disabled{opacity:.5;cursor:not-allowed}.source-block{border:1px solid var(--border);background:#fff;border-radius:8px;flex-direction:column;gap:4px;margin:0 12px;display:flex;padding:10px 12px!important}.source-block-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.remove-btn{color:var(--text-secondary);padding:2px}.remove-btn:hover{color:#ef4444}.source-meta-row{align-items:center;gap:8px;margin-top:8px;display:flex}.source-label-input{flex:1;padding:4px 8px;font-size:12px}.color-swatch{border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:6px;width:28px;height:28px;padding:0}.add-series-btn{border:1px dashed var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:8px;align-items:center;gap:5px;padding:6px 12px;font-size:13px;transition:border-color .15s,color .15s;display:inline-flex}.add-series-btn:hover{border-color:var(--accent);color:var(--accent)}.advanced-options{border:1px solid var(--border);background:#fff;border-radius:8px;padding:8px 10px 10px}.advanced-summary{cursor:pointer;color:var(--text-secondary);font-size:12px;font-weight:600;list-style:none}.advanced-summary::-webkit-details-marker{display:none}.advanced-summary:before{content:"▸";margin-right:6px;transition:transform .12s;display:inline-block}.advanced-options[open] .advanced-summary:before{transform:rotate(90deg)}.range-btn{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:6px;padding:4px 10px;font-size:12px;font-weight:500;transition:border-color .12s,color .12s,background .12s}.range-btn:hover{border-color:var(--accent);color:var(--accent)}.range-btn.active{border-color:var(--accent);color:var(--accent);background:#ecfdf5;font-weight:600}.bucket-pills{flex-wrap:wrap;gap:4px;display:flex}.pop-wrap{display:inline-block;position:relative}.pop-menu{border:1px solid var(--border);z-index:50;background:#fff;border-radius:10px;min-width:180px;max-height:240px;padding:4px;position:absolute;top:calc(100% + 4px);left:0;overflow-y:auto;box-shadow:0 8px 24px #00000014}.pop-menu-right{left:auto;right:0}.pop-item{text-align:left;width:100%;color:var(--text-primary);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:8px;padding:7px 10px;font-size:13px;transition:background .1s;display:flex}.pop-item:hover{background:#f4f6f8}.pop-item.active{color:var(--accent);background:#ecfdf5}.pop-check{border:1px solid var(--border);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;font-size:10px;display:inline-flex}.pop-check.checked{background:var(--accent);border-color:var(--accent);color:#fff}.pop-empty{color:var(--text-secondary);margin:0;padding:8px 10px;font-size:12px}.select-pill{border:1px solid var(--border);color:var(--text-primary);cursor:pointer;background:#fff;border-radius:7px;align-items:center;gap:6px;padding:5px 10px;font-size:13px;transition:border-color .12s;display:inline-flex}.select-pill:hover,.select-pill.active{border-color:var(--accent)}.select-pill:disabled{opacity:.45;cursor:not-allowed}.editor-text-input{width:100%;padding:5px 9px;font-size:13px}@media (width<=900px){.editor-page{height:auto}.editor-body{flex-direction:column;overflow:visible}.editor-options{border-right:none;border-bottom:1px solid var(--border);width:100%}.editor-preview{min-height:320px}.editor-name-input{max-width:200px}}.sidebar-overlay{display:none}@media (width<=900px){.app-shell,.datasource-row,.reports-time-grid,.cadence-picker-grid,.recipient-editor-row,.schedule-group-grid,.schedule-pair-row{grid-template-columns:1fr}.reports-section-header{flex-direction:column;align-items:stretch}.reports-tabs{border-bottom:none;grid-template-columns:1fr 1fr;gap:8px;display:grid}.reports-tab{border:1px solid var(--border);border-radius:8px;margin-bottom:0}.reports-tab-active{background:#f4f8ff;border-color:#c5d6f7}.slideout-backdrop{justify-content:stretch}.slideout-panel,.reports-slideout-panel{width:100vw;box-shadow:none;border-left:none;padding:16px}.sidebar{z-index:40;border-bottom:none;border-right:none;width:240px;height:100vh;transition:left .2s;position:fixed;top:0;left:-260px;box-shadow:0 12px 24px #00000014}.sidebar-open{left:0}.sidebar-overlay{z-index:35;background:#0000002e;display:block;position:fixed;inset:0}.menu-button{display:inline-flex}}.contact-selector{flex-direction:column;gap:12px;display:flex}.contact-group{flex-direction:column;gap:2px;display:flex}.contact-group-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px;font-size:12px;font-weight:500}.contact-check-row{cursor:pointer;border-radius:4px;align-items:center;gap:8px;padding:6px 4px;font-size:13px;display:flex}.contact-check-row:hover{background:var(--canvas-bg)}.contact-check-row input[type=checkbox]{width:15px;height:15px;margin:0}.contact-add-btn{font-size:13px}.contact-add-form{border:1px solid var(--border);background:var(--canvas-bg);border-radius:6px;flex-direction:column;gap:8px;padding:10px;display:flex}.contact-add-row{grid-template-columns:1fr 1fr;gap:8px;display:grid}.contact-add-row input{padding:6px 8px;font-size:13px}.contact-add-actions{justify-content:flex-end;gap:8px;display:flex}.contact-add-actions button{padding:5px 12px;font-size:13px}.device-detail-page{gap:12px;display:grid}.device-general-grid{grid-template-columns:1fr 1px 1fr;align-items:start;gap:24px;display:grid}.device-general-divider{background:var(--border)}.device-section-title{color:var(--text-secondary);margin:0;font-size:14px;font-weight:600}.topbar-device-status{color:var(--text-secondary);align-items:center;gap:6px;font-size:13px;font-weight:500;display:inline-flex}.device-discovered-section{flex-direction:column;gap:8px;margin-top:16px;display:flex}.discovered-topic-card{border:1px solid var(--border);border-radius:6px;padding:10px 12px}.discovered-topic-header{justify-content:space-between;align-items:center;gap:8px;margin-bottom:6px;display:flex}.discovered-topic-name{color:var(--text-secondary);background:var(--canvas-bg);border-radius:4px;padding:2px 6px;font-size:12px}.discovered-topic-payload{color:var(--text-secondary);white-space:pre-wrap;word-break:break-all;max-height:80px;margin:0;font-family:JetBrains Mono,monospace;font-size:11px;overflow:auto}.wizard-listening-bar{color:var(--text-secondary);border:1px solid var(--border);background:var(--canvas-bg);border-radius:6px;align-items:center;gap:8px;padding:8px 12px;font-size:13px;display:flex}.wizard-raw-toggle{color:var(--accent);cursor:pointer;background:0 0;border:none;margin-left:auto;padding:0;font-size:12px}.wizard-raw-panel{border:1px solid var(--border);border-radius:6px;flex-direction:column;gap:8px;max-height:240px;padding:10px 12px;display:flex;overflow:auto}.wizard-raw-status{color:var(--text-secondary);align-items:center;gap:6px;font-size:11px;display:flex}.wizard-raw-dot{background:var(--text-secondary);opacity:.4;border-radius:50%;width:7px;height:7px}.wizard-raw-dot-on{background:var(--accent);opacity:1}.wizard-raw-msg-meta{color:var(--text-secondary);justify-content:space-between;gap:8px;margin-bottom:2px;font-size:11px;display:flex}.wizard-zone-title{align-items:center;gap:6px;margin:4px 0 10px;font-size:14px;display:flex}.wizard-zone-empty{border:1px dashed var(--border);color:var(--text-secondary);border-radius:6px;padding:16px;font-size:13px}.wizard-shape-card{border:1px solid var(--border);border-radius:6px;margin-bottom:12px;padding:12px}.wizard-time-block{flex-direction:column;gap:14px;margin-top:4px;display:flex}.wizard-time-rows{grid-template-columns:max-content 1fr;gap:4px 16px;font-size:13px;display:grid}.wizard-time-rows>div{display:contents}.wizard-time-key{color:var(--text-secondary)}.wizard-time-val{font-size:13px}.wizard-time-drift{color:var(--text-secondary);font-size:13px}.wizard-time-drift-warn{color:#92400e;font-size:13px;font-weight:600}.wizard-time-radios{border:0;flex-direction:column;gap:10px;width:100%;min-width:0;margin:0;padding:0;display:flex}.wizard-time-radios label{cursor:pointer;grid-template-columns:auto 1fr;align-items:start;gap:8px;min-width:0;font-size:14px;line-height:1.45;display:grid}.wizard-time-radios label input{align-self:start;margin:3px 0 0}.wizard-time-radios label>span{min-width:0}.wizard-time-warning{color:#92400e;background:#fffbeb;border:1px solid #fde68a;border-radius:8px;padding:10px 12px;font-size:13px;line-height:1.5}.wizard-shape-card-head{justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;display:flex}.wizard-shape-label{color:var(--accent);align-items:center;gap:6px;font-size:13px;font-weight:600;display:flex}.wizard-shape-topic{color:var(--text-secondary);background:var(--canvas-bg);border-radius:4px;padding:2px 6px;font-size:11px}.wizard-field-table{border-collapse:collapse;width:100%;font-size:13px}.wizard-field-table th{text-align:left;color:var(--text-secondary);padding:4px 8px;font-size:11px;font-weight:500}.wizard-field-table td{border-top:1px solid var(--border);padding:4px 8px}.wizard-field-table code{color:var(--text-secondary);font-size:12px}.wizard-field-excluded{opacity:.45}.wizard-field-name-input{border:1px solid var(--border);border-radius:4px;width:100%;padding:3px 6px;font-size:13px}.wizard-field-sample,.wizard-field-unit-input{font-family:JetBrains Mono,monospace;font-size:12px}.wizard-field-sample-unit{color:var(--text-secondary)}.wizard-field-split-chip{color:var(--accent);vertical-align:middle;cursor:help;background:#0284c714;border:1px solid #0284c740;border-radius:4px;margin-left:6px;padding:1px 6px;font-size:10px;font-weight:500;display:inline-block}.wizard-other-zone{border-top:1px solid var(--border);padding-top:12px}.wizard-other-toggle{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:0;font-size:13px;display:flex}.wizard-other-list{flex-direction:column;gap:8px;margin-top:10px;display:flex}.wizard-other-item{border:1px solid var(--border);border-radius:6px;padding:8px 10px}.wizard-other-cat{margin-bottom:4px;font-size:12px;font-weight:500;display:block}.pv-name{align-items:center;gap:8px;display:inline-flex}.pv-edit-icon{color:var(--text-secondary);cursor:pointer;opacity:0;background:0 0;border:none;justify-content:center;align-items:center;padding:2px;transition:opacity .12s,color .12s;display:inline-flex}.pv-name:hover .pv-edit-icon,.pv-edit-icon:focus-visible{opacity:.7}.pv-edit-icon:hover{opacity:1;color:var(--accent)}.pv-name-input{border:1px solid var(--accent);border-radius:4px;width:100%;max-width:240px;padding:4px 8px;font-size:14px}.channel-name-trigger{color:inherit;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:4px;align-items:center;gap:6px;margin:-2px -4px;padding:2px 4px;transition:background-color .12s,color .12s;display:inline-flex}.channel-name-trigger:hover{background:#0000000a}.channel-name-trigger:hover strong{color:var(--accent)}.channel-name-icon{color:var(--text-secondary);opacity:0;transition:opacity .12s,color .12s}.channel-name-trigger:hover .channel-name-icon,.channel-name-trigger:focus-visible .channel-name-icon{opacity:.8}.channel-name-trigger:hover .channel-name-icon{color:var(--accent)}.channel-unit-suffix{color:var(--text-secondary)}.pv-discovered{color:var(--text-secondary);align-items:center;gap:8px;font-size:13px;display:inline-flex}.pv-new-badge{text-transform:uppercase;letter-spacing:.04em;color:var(--accent);background:var(--accent-bg);border:1px solid var(--accent-border);border-radius:999px;padding:1px 7px;font-size:10px;font-weight:600}.scale-modal-card{width:min(680px,100%)}.channel-config-meta{border-bottom:1px solid var(--border);flex-direction:column;gap:12px;margin-bottom:4px;padding:16px 0 4px;display:flex}.channel-config-row{grid-template-columns:80px 1fr;align-items:center;gap:12px;display:grid}.channel-config-row label{color:var(--text-secondary);font-size:13px;font-weight:500}.channel-config-row input{border:1px solid var(--border);border-radius:6px;padding:6px 10px;font-size:14px}.channel-config-row .scale-field-hint{color:var(--text-secondary);grid-column:2;font-size:11px}.scale-modal-body{flex-wrap:wrap;gap:20px;margin-top:12px;display:flex}.scale-modal-left{flex-direction:column;flex:280px;gap:16px;display:flex}.scale-modal-right{background:var(--canvas-bg);border:1px solid var(--border);border-radius:10px;flex-direction:column;flex:240px;gap:14px;padding:18px;display:flex}.scale-switch{cursor:pointer;align-items:center;gap:10px;font-size:14px;font-weight:500;display:inline-flex}.scale-switch input{opacity:0;width:0;height:0;position:absolute}.scale-switch-track{background:#d1d5db;border-radius:999px;flex-shrink:0;width:38px;height:22px;transition:background .15s;position:relative}.scale-switch-knob{background:#fff;border-radius:999px;width:18px;height:18px;transition:transform .15s;position:absolute;top:2px;left:2px;box-shadow:0 1px 2px #0003}.scale-switch input:checked+.scale-switch-track{background:var(--accent)}.scale-switch input:checked+.scale-switch-track .scale-switch-knob{transform:translate(16px)}.scale-switch input:focus-visible+.scale-switch-track{outline:2px solid var(--accent);outline-offset:2px}.scale-fields{flex-direction:column;gap:14px;display:flex}.scale-field{flex-direction:column;gap:4px;display:flex}.scale-field label{color:var(--text-primary);font-size:13px;font-weight:500}.scale-field input{border:1px solid var(--border);border-radius:6px;width:100%;padding:8px 10px;font-size:14px}.scale-field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light);outline:none}.scale-field-hint{color:var(--text-secondary);font-size:12px}.scale-off-note{color:var(--text-secondary);margin:0;font-size:13px}.scale-warning{color:#92400e;background:#fffbeb;border:1px solid #fde68a;border-radius:8px;padding:10px 12px;font-size:13px;line-height:1.5}.scale-preview-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);font-size:11px;font-weight:600}.scale-preview-block{flex-direction:column;gap:2px;display:flex}.scale-preview-caption{color:var(--text-secondary);font-size:12px}.scale-preview-raw{color:var(--text-primary);font-size:22px;font-weight:600}.scale-steps{border-top:1px dashed var(--border);border-bottom:1px dashed var(--border);flex-direction:column;gap:6px;padding:10px 0;display:flex}.scale-step{justify-content:space-between;align-items:center;font-size:13px;display:flex}.scale-step-op{color:var(--text-secondary)}.scale-step code{color:var(--text-primary);font-size:13px}.scale-preview-final{color:var(--accent);font-size:28px;font-weight:700}.wizard-explainer{text-align:center;max-width:760px}.wizard-explainer-title{margin:0 0 8px;font-size:24px}.wizard-explainer-sub{color:var(--text-secondary);max-width:560px;margin:0 auto 36px;font-size:14px;line-height:1.6}.wizard-explainer-steps{justify-content:center;align-items:stretch;gap:12px;margin-bottom:36px;display:flex}.wizard-explainer-step{border:1px solid var(--border);background:var(--canvas-bg);text-align:center;border-radius:12px;flex:1 1 0;max-width:200px;padding:24px 16px 18px;position:relative}.wizard-explainer-icon{background:var(--accent-bg);width:52px;height:52px;color:var(--accent);border-radius:50%;justify-content:center;align-items:center;margin-bottom:14px;display:inline-flex}.wizard-explainer-step-num{color:var(--text-secondary);opacity:.5;font-size:12px;font-weight:600;position:absolute;top:12px;right:14px}.wizard-explainer-step h4{margin:0 0 6px;font-size:15px}.wizard-explainer-step p{color:var(--text-secondary);margin:0;font-size:12.5px;line-height:1.5}.wizard-explainer-arrow{color:var(--text-secondary);opacity:.4;align-items:center;display:flex}@media (width<=640px){.wizard-explainer-steps{flex-direction:column;align-items:center}.wizard-explainer-step{width:100%;max-width:320px}.wizard-explainer-arrow{transform:rotate(90deg)}}.wizard-fullscreen{z-index:50;background:var(--bg);flex-direction:column;display:flex;position:fixed;inset:0}.wizard-fullscreen-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.wizard-fullscreen-header h2{color:var(--text-secondary);margin:0;font-size:18px}.wizard-fullscreen-body{flex-direction:column;flex:1;align-items:center;padding:32px 24px;display:flex;overflow-y:auto}.wizard-content{flex-direction:column;align-items:center;width:100%;display:flex}.wizard-step-indicator{gap:6px;margin-bottom:16px;display:flex}.wizard-step-dot{background:var(--border);border-radius:2px;width:32px;height:4px}.wizard-step-dot-active{background:var(--accent)}.wizard-connection-info{border:1px solid var(--border);border-radius:6px;flex-direction:column;gap:6px;padding:10px 12px;display:flex}.wizard-token-placeholder{border:1px dashed var(--border);background:#fafafa;border-radius:6px;padding:12px}.device-setup-banner{background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #fbbf24;border-radius:8px;justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;padding:16px 20px;display:flex}.device-setup-banner strong{color:#92400e}.device-clock-drift-banner{background:#fffbeb;border:1px solid #fde68a;border-radius:8px;margin-bottom:20px;padding:12px 16px}.device-clock-drift-banner strong{color:#92400e}.wizard-encryption-toggle{background:#f1f5f9;border-radius:6px;gap:2px;margin-bottom:4px;padding:3px;display:flex}.wizard-encryption-toggle button{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;flex:1;padding:6px 12px;font-size:12px;font-weight:500}.wizard-encryption-toggle button.active{color:var(--text-primary);background:#fff;box-shadow:0 1px 3px #00000014}.wizard-tls-note{color:#92400e;background:#fef3c7;border-radius:4px;margin-top:4px;padding:6px 10px;font-size:12px}.device-status-incomplete{color:#b45309;background:#fef3c7;border-radius:4px;align-items:center;gap:4px;margin-left:8px;padding:2px 8px;font-size:12px;display:inline-flex}.device-row-incomplete-cta{color:#0284c7;cursor:pointer;background:0 0;border:1px solid #0284c7;border-radius:4px;margin-left:8px;padding:4px 10px;font-size:12px;font-weight:500}.device-row-incomplete-cta:hover{background:#f0f9ff}.wizard-connection-row{justify-content:space-between;font-size:13px;display:flex}.wizard-connection-label{color:var(--text-secondary)}.wizard-connection-value{font-family:JetBrains Mono,monospace;font-size:12px}.wizard-listening-status{flex-direction:column;gap:10px;display:flex}.wizard-listening-indicator{border:1px solid var(--border);background:var(--canvas-bg);border-radius:6px;align-items:flex-start;gap:10px;padding:12px;display:flex}.wizard-listening-indicator svg{color:var(--text-secondary);flex-shrink:0;margin-top:1px}.wizard-listening-success{border-color:var(--accent);background:var(--accent-light)}.wizard-listening-success svg{color:var(--accent)}.wizard-listening-title{margin:0;font-size:13px;font-weight:500}@keyframes wizard-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.wizard-intro{text-align:center;animation:.3s ease-out welcome-fade-in}.wizard-intro-animation{justify-content:center;align-items:center;gap:18px;margin:16px auto 32px;display:flex}.wizard-intro-icon{color:#fff;background:linear-gradient(135deg,#0284c7,#38bdf8);border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;animation:.5s ease-out both wizard-intro-pop;display:inline-flex;box-shadow:0 8px 24px #0284c740}.wizard-intro-icon-1{animation-delay:.1s}.wizard-intro-icon-2{animation-delay:.3s}.wizard-intro-icon-3{animation-delay:.5s}.wizard-intro-pulse-line{background:linear-gradient(90deg,#38bdf8 0%,#38bdf833 50%,#38bdf8 100%) 0 0/200% 100%;border-radius:1px;width:56px;height:2px;animation:1.8s ease-in-out infinite wizard-intro-pulse;position:relative;overflow:hidden}.wizard-intro-pulse-line-1{animation-delay:.2s}.wizard-intro-pulse-line-2{animation-delay:.4s}@keyframes wizard-intro-pop{0%{opacity:0;transform:scale(.5)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes wizard-intro-pulse{0%,to{opacity:.7;background-position:200% 0}50%{opacity:1;background-position:0 0}}.wizard-intro-title{color:var(--text-primary);margin:0 0 12px;font-size:22px;font-weight:600}.wizard-intro-text{color:var(--text-secondary);max-width:460px;margin:0 auto 24px;font-size:14px;line-height:1.6}.wizard-intro-list{text-align:left;color:var(--text-secondary);flex-direction:column;gap:10px;margin:0 auto 24px;padding:0;font-size:13px;list-style:none;display:inline-flex}.wizard-intro-list li{align-items:center;gap:10px;display:flex}.wizard-intro-dot{background:#0284c7;border-radius:50%;flex-shrink:0;width:6px;height:6px}.wizard-spin{animation:1s linear infinite wizard-spin}@media (width<=768px){.device-general-grid{grid-template-columns:1fr;gap:16px}.device-general-divider{width:100%;height:1px}}.usage-bar-container{margin-bottom:12px}.usage-bar-header{justify-content:space-between;margin-bottom:4px;font-size:13px;display:flex}.usage-bar-label{color:var(--text-primary);font-weight:500}.usage-bar-value{color:var(--text-secondary)}.usage-bar-track{background:var(--border);border-radius:4px;height:8px;overflow:hidden}.usage-bar-fill{border-radius:4px;height:100%;transition:width .3s}.usage-bar-fill-green{background:var(--accent)}.usage-bar-fill-yellow{background:#f59e0b}.usage-bar-fill-red{background:#ef4444}.plan-card{border:1px solid var(--border);text-align:center;border-radius:8px;padding:20px;position:relative}.plan-card-current{border-color:var(--accent);background:var(--accent-light)}.plan-card-badge{background:var(--accent);color:#fff;white-space:nowrap;border-radius:10px;padding:2px 10px;font-size:11px;font-weight:600;position:absolute;top:-10px;left:50%;transform:translate(-50%)}.plan-card-name{margin:0 0 8px;font-size:18px;font-weight:600}.plan-card-price{margin-bottom:12px}.plan-card-amount{color:var(--text-primary);font-size:20px;font-weight:600}.plan-card-monthly{color:var(--text-secondary);margin-top:2px;font-size:12px;display:block}.plan-card-features{color:var(--text-secondary);margin:0 0 16px;padding:0;font-size:13px;list-style:none}.plan-card-features li{padding:4px 0}.settings-billing-panel{max-width:100%}.settings-billing-panel .pricing-hero{margin-top:8px}.settings-billing-panel .pricing-hero h1{font-size:22px}.settings-billing-panel .pricing-grid{grid-template-columns:repeat(4,1fr);margin-bottom:32px}@media (width<=1100px){.settings-billing-panel .pricing-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=700px){.settings-billing-panel .pricing-grid{grid-template-columns:1fr}}.billing-summary{border:1px solid var(--border);background:#fff;border-radius:10px;margin-bottom:32px;padding:24px}.billing-summary-plan{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.billing-summary-title{align-items:center;gap:8px;margin:0;font-size:20px;font-weight:600;display:flex}.billing-summary-period{color:var(--text-secondary);margin:4px 0 0;font-size:13px}.billing-manage-btn{border:1px solid var(--border);color:var(--text-primary);cursor:pointer;white-space:nowrap;background:#fff;border-radius:6px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:500;transition:background .15s;display:inline-flex}.billing-manage-btn:hover{background:#f8fafc}.billing-summary-usage{grid-template-columns:1fr 1fr;gap:20px;display:grid}.billing-usage-item{flex-direction:column;gap:6px;display:flex}.billing-usage-header{justify-content:space-between;align-items:baseline;display:flex}.billing-usage-label{color:var(--text-secondary);font-size:13px;font-weight:500}.billing-usage-value{color:var(--text-primary);font-size:13px;font-weight:600}.billing-usage-bar-track{background:#f1f5f9;border-radius:3px;height:6px;overflow:hidden}.billing-usage-bar-fill{background:#0284c7;border-radius:3px;height:100%;transition:width .4s}.billing-usage-bar-warning{background:linear-gradient(90deg,#f59e0b,#ef4444)}.pricing-btn-upgrade{color:#fff;background:#0284c7;border-color:#0284c7}.pricing-btn-upgrade:hover:not(:disabled){background:#0369a1}.calculator-container{border:1px solid var(--border);border-radius:8px;padding:16px}.calculator-title{margin:0 0 12px;font-size:15px;font-weight:600}.calculator-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:16px;display:grid}.calculator-field{color:var(--text-secondary);flex-direction:column;gap:4px;font-size:13px;display:flex}.calculator-field input{border:1px solid var(--border);border-radius:6px;padding:8px 10px;font-size:14px}.calculator-result{background:var(--accent-light);border-radius:6px;padding:12px}.calculator-estimate{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.calculator-estimate-label{color:var(--text-secondary);font-size:13px}.calculator-estimate-value{color:var(--text-primary);font-size:18px;font-weight:600}.calculator-recommendation{color:var(--text-secondary);font-size:13px}.admin-stats-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;display:grid}.admin-stat-card{border:1px solid var(--border);text-align:center;border-radius:8px;flex-direction:column;align-items:center;padding:16px;display:flex}.admin-stat-value{color:var(--text-primary);font-size:24px;font-weight:600}.admin-stat-label{color:var(--text-secondary);margin-top:4px;font-size:12px}.admin-quick-links{gap:8px;display:flex}.admin-search-input{border:1px solid var(--border);border-radius:6px;width:100%;max-width:320px;padding:8px 12px;font-size:14px}.admin-pagination{color:var(--text-secondary);align-items:center;gap:12px;font-size:13px;display:flex}.admin-back-link{color:var(--text-secondary);font-size:13px;text-decoration:none}.admin-back-link:hover{color:var(--text-primary)}.text-secondary{color:var(--text-secondary);font-size:13px}.admin-team-section{border:1px solid var(--border);border-radius:8px;padding:16px}.admin-team-section h3{margin:0 0 12px;font-size:15px}.admin-plan-controls{align-items:center;gap:8px;display:flex}.admin-plan-controls select{border:1px solid var(--border);border-radius:6px;padding:8px 12px;font-size:14px}.admin-code-generator{border:1px solid var(--border);border-radius:8px;padding:16px}.admin-code-generator h3{margin:0 0 12px;font-size:15px}.admin-code-form{flex-wrap:wrap;align-items:flex-end;gap:12px;display:flex}.admin-code-field{color:var(--text-secondary);flex-direction:column;gap:4px;font-size:13px;display:flex}.admin-code-field select,.admin-code-field input{border:1px solid var(--border);border-radius:6px;padding:8px 10px;font-size:14px}.admin-generated-code{background:var(--accent-light);border-radius:6px;align-items:center;gap:12px;margin-top:16px;padding:12px;display:flex}.admin-code-display{letter-spacing:2px;color:var(--text-primary);font-family:JetBrains Mono,monospace;font-size:18px;font-weight:600}.admin-code-list-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.admin-code-list-header h3{margin:0;font-size:15px}.admin-code-list-header select{border:1px solid var(--border);border-radius:6px;padding:6px 10px;font-size:13px}.admin-code-inline{cursor:pointer;background:var(--canvas-bg);border-radius:4px;padding:2px 6px;font-family:JetBrains Mono,monospace;font-size:12px}.admin-code-inline:hover{background:var(--accent-light)}.admin-plans-summary{border:1px solid var(--border);border-radius:8px;padding:16px}.admin-plans-summary h3{margin:0 0 12px;font-size:15px}.btn-danger-text{color:#ef4444;cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:13px}.btn-danger-text:hover{text-decoration:underline}.billing-status-badge{vertical-align:middle;border-radius:4px;margin-left:8px;padding:2px 8px;font-size:12px;font-weight:500;display:inline-block}.billing-status-past-due{color:#92400e;background:#fef3c7}.billing-status-canceled{color:#991b1b;background:#fee2e2}.plan-card-actions{gap:6px;display:flex}.plan-card-actions .btn{flex:1;padding:6px 10px;font-size:13px}.upgrade-success-modal{background:#fff;border-radius:16px;width:min(420px,90vw);animation:.3s ease-out welcome-fade-in;position:relative;overflow:hidden}.upgrade-success-confetti{pointer-events:none;height:200px;position:absolute;top:0;left:0;right:0;overflow:hidden}.confetti-piece{opacity:0;border-radius:2px;width:8px;height:8px;animation:2s ease-in forwards confetti-fall;position:absolute;top:-10px}@keyframes confetti-fall{0%{opacity:1;transform:translateY(0)rotate(0)}to{opacity:0;transform:translateY(200px)rotate(720deg)}}.upgrade-success-content{text-align:center;padding:48px 32px 32px}.upgrade-success-icon{color:#fff;background:#0284c7;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:16px;animation:.4s ease-out .2s both welcome-icon-pop;display:inline-flex}.upgrade-success-content h2{margin:0 0 8px;font-size:22px;font-weight:700}.upgrade-success-content p{color:var(--text-secondary);margin:0 0 24px;font-size:14px;line-height:1.5}.upgrade-success-content .pricing-btn{width:auto;padding:10px 28px;display:inline-block}.form-error{color:#dc2626;margin:4px 0 0;font-size:13px}.upgrade-gate-modal{width:min(440px,100%);padding:0;animation:.25s ease-out welcome-fade-in;position:relative;overflow:hidden}.upgrade-gate-close{z-index:1;position:absolute;top:14px;right:14px}.upgrade-gate-hero{text-align:center;background:linear-gradient(#fef3f2 0%,#fff 100%);padding:36px 28px 20px}.upgrade-gate-icon{color:#fff;background:#0284c7;border-radius:14px;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:16px;animation:.4s ease-out both welcome-icon-pop;display:inline-flex}.upgrade-gate-title{color:var(--text-primary);margin:0 0 8px;font-size:20px;font-weight:600}.upgrade-gate-subtitle{color:var(--text-secondary);margin:0;font-size:14px;line-height:1.5}.upgrade-gate-usage{padding:16px 28px 20px}.upgrade-gate-bar-track{background:#f3f4f6;border-radius:4px;height:8px;overflow:hidden}.upgrade-gate-bar-fill{background:linear-gradient(90deg,#0284c7,#f97316);border-radius:4px;height:100%;transition:width .4s}.upgrade-gate-bar-label{color:var(--text-secondary);text-align:center;margin:6px 0 0;font-size:12px}.upgrade-gate-actions{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:16px 28px;display:flex}.upgrade-gate-cta{color:#fff;cursor:pointer;background:#0284c7;border:none;border-radius:6px;align-items:center;gap:6px;padding:8px 18px;font-size:14px;font-weight:500;display:inline-flex}.upgrade-gate-cta:hover{background:#0369a1}.welcome-modal{width:min(640px,96vw);padding:0;animation:.25s ease-out welcome-fade-in;position:relative;overflow:hidden}@keyframes welcome-fade-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.welcome-close{z-index:1;position:absolute;top:14px;right:14px}.welcome-hero{text-align:center;background:linear-gradient(#f0f7ff 0%,#fff 100%);padding:48px 36px 32px}.welcome-icon-cluster{justify-content:center;gap:14px;margin-bottom:24px;display:flex}.welcome-icon-bubble{color:#fff;border-radius:14px;justify-content:center;align-items:center;width:56px;height:56px;animation:.4s ease-out both welcome-icon-pop;display:inline-flex}.welcome-icon-1{background:#0284c7;animation-delay:.1s}.welcome-icon-2{background:#0ea5e9;animation-delay:.2s}.welcome-icon-3{background:#38bdf8;animation-delay:.3s}@keyframes welcome-icon-pop{0%{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}.welcome-title{color:var(--text-primary);margin:0 0 10px;font-size:26px;font-weight:600}.welcome-subtitle{color:var(--text-secondary);max-width:440px;margin:0 auto;font-size:15px;line-height:1.5}.welcome-steps{flex-direction:column;gap:18px;padding:28px 36px;display:flex}.welcome-step{align-items:flex-start;gap:16px;display:flex}.welcome-step-number{color:#0284c7;background:#f0f7ff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;margin-top:1px;font-size:14px;font-weight:600;display:inline-flex}.welcome-step-title{color:var(--text-primary);margin:0 0 3px;font-size:15px;font-weight:500}.welcome-step-desc{color:var(--text-secondary);margin:0;font-size:13.5px;line-height:1.5}.welcome-actions{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:20px 36px 24px;display:flex}.welcome-cta{color:#fff;cursor:pointer;background:#0284c7;border:none;border-radius:6px;padding:8px 18px;font-size:14px;font-weight:500}.welcome-cta:hover{background:#0369a1}.react-grid-layout{transition:height .2s;position:relative}.react-grid-item{transition:left .2s,top .2s,width .2s,height .2s}.react-grid-item img{pointer-events:none;-webkit-user-select:none;user-select:none}.react-grid-item.cssTransforms{transition-property:transform,width,height}.react-grid-item.resizing{z-index:1;will-change:width, height;transition:none}.react-grid-item.react-draggable-dragging{z-index:3;will-change:transform;transition:none}.react-grid-item.dropping{visibility:hidden}.react-grid-item.react-grid-placeholder{opacity:.2;z-index:2;-webkit-user-select:none;user-select:none;background:red;transition-duration:.1s}.react-grid-item.react-grid-placeholder.placeholder-resizing{transition:none}.react-grid-item>.react-resizable-handle{opacity:0;width:20px;height:20px;position:absolute}.react-grid-item:hover>.react-resizable-handle{opacity:1}.react-grid-item>.react-resizable-handle:after{content:"";border-bottom:2px solid #0006;border-right:2px solid #0006;width:5px;height:5px;position:absolute;bottom:3px;right:3px}.react-resizable-hide>.react-resizable-handle{display:none}.react-grid-item>.react-resizable-handle.react-resizable-handle-sw{cursor:sw-resize;bottom:0;left:0;transform:rotate(90deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-se{cursor:se-resize;bottom:0;right:0}.react-grid-item>.react-resizable-handle.react-resizable-handle-nw{cursor:nw-resize;top:0;left:0;transform:rotate(180deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-ne{cursor:ne-resize;top:0;right:0;transform:rotate(270deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-w,.react-grid-item>.react-resizable-handle.react-resizable-handle-e{cursor:ew-resize;margin-top:-10px;top:50%}.react-grid-item>.react-resizable-handle.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-n,.react-grid-item>.react-resizable-handle.react-resizable-handle-s{cursor:ns-resize;margin-left:-10px;left:50%}.react-grid-item>.react-resizable-handle.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.react-resizable{position:relative}.react-resizable-handle{box-sizing:border-box;background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA2IDYiIHN0eWxlPSJiYWNrZ3JvdW5kLWNvbG9yOiNmZmZmZmYwMCIgeD0iMHB4IiB5PSIwcHgiIHdpZHRoPSI2cHgiIGhlaWdodD0iNnB4Ij48ZyBvcGFjaXR5PSIwLjMwMiI+PHBhdGggZD0iTSA2IDYgTCAwIDYgTCAwIDQuMiBMIDQgNC4yIEwgNC4yIDQuMiBMIDQuMiAwIEwgNiAwIEwgNiA2IEwgNiA2IFoiIGZpbGw9IiMwMDAwMDAiLz48L2c+PC9zdmc+);background-position:100% 100%;background-repeat:no-repeat;background-origin:content-box;width:20px;height:20px;padding:0 3px 3px 0;position:absolute}.react-resizable-handle-sw{cursor:sw-resize;bottom:0;left:0;transform:rotate(90deg)}.react-resizable-handle-se{cursor:se-resize;bottom:0;right:0}.react-resizable-handle-nw{cursor:nw-resize;top:0;left:0;transform:rotate(180deg)}.react-resizable-handle-ne{cursor:ne-resize;top:0;right:0;transform:rotate(270deg)}.react-resizable-handle-w,.react-resizable-handle-e{cursor:ew-resize;margin-top:-10px;top:50%}.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-resizable-handle-n,.react-resizable-handle-s{cursor:ns-resize;margin-left:-10px;left:50%}.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}
