:root{--primary-color:#0f172a;--sidebar-bg:#fff;--sidebar-text:#555;--sidebar-active-bg:#f0f0ed;--accent-color:#0f172a;--primary-hover:#1e293b}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#1a1a1a;background:#f5f5f3;min-height:100vh;margin:0;font-family:DM Sans,sans-serif}.min-h-screen{min-height:100vh}.w-full{width:100%}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.px-4{padding-left:1rem;padding-right:1rem}.relative{position:relative}.absolute{position:absolute}.mb-4{margin-bottom:1rem}.mb-8{margin-bottom:2rem}.mx-auto{margin-left:auto;margin-right:auto}.text-center{text-align:center}.gap-1\.5{gap:.375rem}.gap-4{gap:1rem}.mb-6{margin-bottom:1.5rem}.p-3{padding:.75rem}.bg-red-50{background-color:#fef2f2}.text-red-600{color:#dc2626}.text-xs{font-size:.75rem}.font-medium{font-weight:500}.border-red-100{border-color:#fee2e2}.rounded-md{border-radius:.375rem}.mt-2{margin-top:.5rem}.pt-6{padding-top:1.5rem}.border-t{border-top:1px solid #e2e8f0}.bg-light{background-color:#f8fafc}.login-card{background:var(--sidebar-bg);border:1px solid #e2e8f0;border-radius:20px;width:100%;max-width:400px;padding:40px;box-shadow:0 20px 25px -5px #0000000d,0 10px 10px -5px #00000005}.card-premium{position:relative;overflow:hidden}.card-premium:before{content:"";background:linear-gradient(90deg,#0f172a,#334155);height:4px;position:absolute;top:0;left:0;right:0}.h1{color:#0f172a;margin-bottom:4px;font-size:28px;font-weight:700}.caption{color:#64748b;font-size:13px;font-weight:500}.login-card label.caption{margin-bottom:6px;display:block}.login-card input{color:#0f172a;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;outline:none;width:100%;height:44px;padding:0 14px;font-family:DM Sans,sans-serif;font-size:14px;transition:all .2s}.login-card input:focus{background:var(--sidebar-bg);border-color:#0f172a;box-shadow:0 0 0 4px #0f172a14}#root{width:100%;min-height:100vh;display:flex}.sidebar{background:var(--sidebar-bg);border-right:1px solid #e8e8e4;flex-direction:column;flex-shrink:0;width:220px;height:100vh;padding:0;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar-brand{border-bottom:1px solid #e8e8e4;align-items:center;gap:10px;padding:20px 18px 18px;display:flex}.brand-icon{background:var(--primary-color);color:#fff;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:15px;font-weight:600;display:flex}.brand-name{color:var(--primary-color);font-size:14px;font-weight:600;line-height:1.2}.brand-sub{color:#888;letter-spacing:.05em;text-transform:uppercase;font-size:10px}.nav{flex:1;padding:12px 0}.nav-item{color:var(--sidebar-text);cursor:pointer;border-left:2.5px solid #0000;align-items:center;gap:10px;padding:9px 18px;font-size:13.5px;text-decoration:none;transition:all .12s;display:flex}.nav-item:hover{color:var(--primary-color);background:#f8f8f6}.nav-item.active{color:var(--primary-color);border-left-color:var(--primary-color);background:#f0f0ed;font-weight:500}.nav-item svg{opacity:.6;flex-shrink:0}.nav-item.active svg{opacity:1}.sidebar-footer{border-top:1px solid #e8e8e4;padding:16px 18px}.sidebar-footer span{color:#aaa;font-size:11px}.sub-nav{padding-bottom:8px}.sub-item{opacity:.8;border-left:none!important}.sub-item.active{opacity:1;color:var(--primary-color)!important;background:0 0!important;font-weight:600!important}.sub-item:hover{opacity:1;background:#f8f8f6!important}.main{flex-direction:column;flex:1;min-width:0;min-height:100vh;display:flex}.topbar{background:#fff;border-bottom:1px solid #e8e8e4;align-items:center;gap:16px;height:56px;padding:0 28px;display:flex}.topbar-search{background:#f5f5f3;border:1px solid #e8e8e4;border-radius:8px;flex:1;align-items:center;gap:8px;max-width:400px;height:36px;padding:0 12px;display:flex}.topbar-search svg{color:#aaa;flex-shrink:0}.topbar-search input{color:#1a1a1a;background:0 0;border:none;outline:none;width:100%;font-family:DM Sans,sans-serif;font-size:13px}.topbar-search input::placeholder{color:#aaa}.topbar-right{align-items:center;margin-left:auto;display:flex;position:relative}.topbar-user-trigger{cursor:pointer;border-radius:12px;align-items:center;gap:12px;padding:6px 10px;transition:all .2s;display:flex}.topbar-user-trigger:hover{background:#f8fafc}.topbar-avatar{background:var(--primary-color);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:600;display:flex}.topbar-user{color:#64748b;font-size:11px;line-height:1.2}.topbar-user strong{color:var(--primary-color);font-size:13px;font-weight:600;display:block}.dropdown-arrow{color:#94a3b8;margin-left:4px;transition:transform .2s}.dropdown-arrow.open{transform:rotate(180deg)}.header-dropdown{z-index:1000;background:#fff;border:1px solid #e2e8f0;border-radius:16px;width:220px;animation:.2s ease-out slideDown;position:absolute;top:calc(100% + 10px);right:0;overflow:hidden;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{background:#f8fafc;padding:16px}.dropdown-name{color:var(--primary-color);font-size:13px;font-weight:600}.dropdown-email{color:#64748b;margin-top:2px;font-size:11px}.dropdown-divider{background:#e2e8f0;height:1px}.dropdown-item{color:#475569;text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:12px 16px;font-size:13px;text-decoration:none;transition:all .2s;display:flex}.dropdown-item:hover{color:var(--primary-color);background:#f1f5f9}.logout-item{color:#ef4444}.logout-item:hover{color:#ef4444;background:#fef2f2}.content{flex:1;min-width:0;padding:32px 28px;overflow-x:hidden}.page-header{justify-content:space-between;align-items:flex-start;margin-bottom:28px;display:flex}.page-title{color:#0f172a;font-size:22px;font-weight:600}.page-sub{color:#888;margin-top:4px;font-size:13px}.btn-primary{color:#fff;cursor:pointer;white-space:nowrap;background:#0f172a;border:none;border-radius:9px;align-items:center;gap:7px;padding:10px 18px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;transition:background .12s;display:inline-flex}.btn-primary:hover{background:var(--primary-hover)}.stats-row{grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:24px;display:grid}.stat-label{color:#999;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:11.5px}.stat-val{color:#0f172a;font-size:24px;font-weight:600}.stat-val .unit{color:#999;margin-left:4px;font-size:13px;font-weight:400}.table-card{background:#fff;border:1px solid #e8e8e4;border-radius:14px;overflow:hidden}.toolbar{border-bottom:1px solid #e8e8e4;align-items:center;gap:10px;padding:14px 16px;display:flex}.search-box{background:#f7f7f5;border:1px solid #e8e8e4;border-radius:8px;flex:1;align-items:center;gap:8px;height:36px;padding:0 12px;display:flex}.search-box svg{color:#bbb;flex-shrink:0}.search-box input::placeholder{color:#bbb}.filter-select{height:36px;color:var(--sidebar-text);cursor:pointer;white-space:nowrap;background:#f7f7f5;border:1px solid #e8e8e4;border-radius:8px;align-items:center;gap:7px;padding:0 12px;font-family:DM Sans,sans-serif;font-size:13px;display:flex;position:relative}.filter-select select{opacity:0;cursor:pointer;width:100%;font-size:13px;position:absolute;inset:0}thead tr{background:#fafaf9}th{color:#999;text-transform:uppercase;letter-spacing:.07em;text-align:left;white-space:nowrap;border-bottom:1px solid #e8e8e4;padding:11px 16px;font-size:11px;font-weight:600}th:last-child{text-align:right}tbody tr{border-bottom:1px solid #f0f0ed;transition:background .1s}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:#fafaf9}td{vertical-align:middle;padding:15px 16px;font-size:13.5px}.file-cell{align-items:center;gap:12px;display:flex}.file-icon-wrap{background:#eef4fd;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.file-name{color:#0f172a;font-size:13.5px;font-weight:500;line-height:1.3}.file-link{color:#0f172a;cursor:pointer;align-items:center;gap:4px;margin-top:3px;font-size:11.5px;text-decoration:none;display:inline-flex}.file-link:hover{text-decoration:underline}.badge{white-space:nowrap;border-radius:20px;align-items:center;gap:5px;padding:4px 11px;font-size:11.5px;font-weight:500;display:inline-flex}.badge-cat{color:#4338ca;background:#eef}.badge-free{color:#065f46;background:#ecfdf5}.badge-premium{color:#92400e;background:#fffbeb}.badge-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px;display:inline-block}.badge-free .badge-dot{background:#10b981}.badge-premium .badge-dot{background:#f59e0b}.actions-cell{justify-content:flex-end;align-items:center;gap:6px;display:flex}.icon-btn{cursor:pointer;color:#888;background:#fff;border:1px solid #e8e8e4;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .12s;display:flex}.icon-btn:hover{color:#0f172a;background:#f5f5f3;border-color:#ccc}.icon-btn.del:hover{color:#b91c1c;background:#fef2f2;border-color:#fca5a5}.table-footer{border-top:1px solid #f0f0ed;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.pg-btn{cursor:pointer;width:28px;height:28px;color:var(--sidebar-text);background:#fff;border:1px solid #e8e8e4;border-radius:6px;justify-content:center;align-items:center;font-family:DM Sans,sans-serif;font-size:12px;display:flex}.toast-container{z-index:99999;pointer-events:none;flex-direction:column;gap:12px;display:flex;position:fixed;top:24px;right:24px}.toast-item{pointer-events:auto;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #0000000d;border-radius:12px;align-items:center;gap:12px;min-width:320px;max-width:420px;padding:14px 16px;display:flex;position:relative;overflow:hidden;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a}.toast-icon{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.toast-content{color:#1a1a1a;flex:1;font-size:13.5px;font-weight:500;line-height:1.4}.toast-close{color:#999;cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;padding:4px;transition:all .2s}.toast-close:hover{color:#666;background:#0000000d}.toast-success .toast-icon{color:#059669;background:#ecfdf5}.toast-success{border-left:4px solid #10b981}.toast-error .toast-icon{color:#dc2626;background:#fef2f2}.toast-error{border-left:4px solid #ef4444}.toast-warning .toast-icon{color:#d97706;background:#fffbeb}.toast-warning{border-left:4px solid #f59e0b}.toast-info .toast-icon{color:#0f172a;background:#f1f5f9}.toast-info{border-left:4px solid #0f172a}.dept-header{justify-content:space-between;align-items:flex-end;margin-bottom:24px;display:flex}.dept-title-group{flex:1}.dept-card{background:#fff;border:1px solid #e8e8e4;border-radius:16px;margin-bottom:20px;transition:all .2s;overflow:hidden}.dept-card:hover{border-color:#d1d5db;box-shadow:0 10px 15px -3px #0000000a}.dept-card-header{background:#fafafa;border-bottom:1px solid #f0f0ed;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.dept-card-icon{color:#0f172a;background:#fff;border:1px solid #e8e8e4;border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.tree-container{padding:12px 0}.tree-branch{position:relative}.tree-branch:before{content:"";background:#e2e8f0;width:1px;position:absolute;top:0;bottom:0;left:16px}.tree-branch.is-last:before{height:22px}.tree-node{align-items:center;padding:8px 16px;transition:background .1s;display:flex;position:relative}.tree-node:hover{background:#f8f8f6}.tree-node:before{content:"";background:#e2e8f0;width:12px;height:1px;position:absolute;top:50%;left:16px}.tree-icon{z-index:1;background:#fff;border:1px solid #e2e8f0;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;margin-right:12px;transition:all .2s;display:flex}.tree-node:hover .tree-icon{border-color:#94a3b8;transform:scale(1.05)}.actions{opacity:0;transition:opacity .2s}.tree-node:hover .actions{opacity:1}.text-danger{color:#ef4444}.p-1\.5{padding:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-hidden{overflow:hidden}.pg-btn:hover:not(.active){background:#f5f5f3}.modal-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100;background:#0f172a59;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.modal-overlay.open{display:flex}.modal{background:#fff;border-radius:16px;width:100%;max-width:500px;max-height:90vh;padding:28px;animation:.18s modalIn;position:relative;overflow-y:auto;box-shadow:0 8px 40px #0000001f}@keyframes modalIn{0%{opacity:0;transform:translateY(10px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-close{cursor:pointer;color:#888;background:#f7f7f5;border:1px solid #e8e8e4;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;transition:all .12s;display:flex;position:absolute;top:18px;right:18px}.modal-close:hover{color:#b91c1c;background:#fef2f2;border-color:#fca5a5}.modal-title{color:#0f172a;margin-bottom:3px;font-size:17px;font-weight:600}.modal-sub{color:#999;margin-bottom:22px;font-size:12.5px}.form-group{margin-bottom:18px}.form-label{color:var(--sidebar-text);letter-spacing:.02em;margin-bottom:6px;font-size:12px;font-weight:500;display:block}.form-label span{color:#e24b4a;margin-left:2px}.form-input{color:#0f172a;background:#fff;border:1px solid #e8e8e4;border-radius:9px;outline:none;width:100%;height:40px;padding:0 13px;font-family:DM Sans,sans-serif;font-size:13.5px;transition:border-color .12s}.form-input::placeholder{color:#bbb}.form-input:focus{border-color:#94a3b8;box-shadow:0 0 0 3px #94a3b826}.tab-group{background:#f1f1ee;border-radius:9px;grid-template-columns:1fr 1fr;gap:3px;margin-bottom:14px;padding:3px;display:grid}.tab-btn{cursor:pointer;color:#888;background:0 0;border:none;border-radius:7px;padding:8px 0;font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;transition:all .15s}.tab-btn.active{color:#0f172a;background:#fff;box-shadow:0 1px 4px #00000014}.url-input-wrap{position:relative}.url-input-wrap .url-prefix{color:#bbb;pointer-events:none;font-size:13px;position:absolute;top:50%;left:13px;transform:translateY(-50%)}.url-input-wrap .form-input{color:#0f172a;padding-left:13px}.url-input-wrap .form-input::placeholder{color:#bbb}.upload-zone{text-align:center;cursor:pointer;background:#fafafa;border:1.5px dashed #d1d5db;border-radius:10px;padding:22px 16px;transition:all .15s}.upload-zone:hover{background:#f5f8ff;border-color:#94a3b8}.upload-zone-icon{background:#eef4fd;border-radius:9px;justify-content:center;align-items:center;width:36px;height:36px;margin:0 auto 10px;display:flex}.upload-zone p{color:#666;font-size:13px;line-height:1.5}.upload-zone p strong{color:#0f172a;font-weight:500}.upload-zone small{color:#aaa;font-size:11px}.form-select{color:#0f172a;appearance:none;cursor:pointer;background:#fff url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23aaa' stroke-width='1.3' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") right 13px center no-repeat;border:1px solid #e8e8e4;border-radius:9px;outline:none;width:100%;height:40px;padding:0 13px;font-family:DM Sans,sans-serif;font-size:13.5px;transition:border-color .12s}.form-select:focus{border-color:#94a3b8;box-shadow:0 0 0 3px #94a3b826}.form-select option[value=""]{color:#bbb}.access-row{background:#f7f7f5;border:1px solid #e8e8e4;border-radius:10px;align-items:center;gap:14px;padding:13px 15px;display:flex}.toggle-wrap{flex-shrink:0;position:relative}.toggle-wrap input[type=checkbox]{opacity:0;width:0;height:0;position:absolute}.toggle-track{cursor:pointer;background:#d1d5db;border-radius:11px;width:38px;height:22px;transition:background .2s;display:block;position:relative}.toggle-track:after{content:"";background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #00000026}.toggle-wrap input:checked+.toggle-track{background:#0f172a}.toggle-wrap input:checked+.toggle-track:after{transform:translate(16px)}.access-text{flex:1}.access-text strong{color:#0f172a;font-size:13px;font-weight:500;display:block}.access-text span{color:#999;font-size:11.5px}.modal-footer{gap:10px;margin-top:24px;display:flex}.btn-discard{height:40px;color:var(--sidebar-text);cursor:pointer;background:#fff;border:1px solid #e8e8e4;border-radius:9px;flex:1;font-family:DM Sans,sans-serif;font-size:13.5px;font-weight:500;transition:all .12s}.btn-discard:hover{background:#f7f7f5}.btn-save{color:#fff;cursor:pointer;background:#0f172a;border:none;border-radius:9px;flex:2;justify-content:center;align-items:center;gap:7px;height:40px;font-family:DM Sans,sans-serif;font-size:13.5px;font-weight:500;transition:background .12s;display:flex}.btn-save:hover{background:var(--primary-hover)}.subs-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.plan-card{background:#fff;border:1px solid #e8e8e4;border-radius:16px;flex-direction:column;gap:14px;padding:20px;transition:box-shadow .15s;display:flex}.plan-card:hover{box-shadow:0 4px 20px #00000012}.plan-card-featured{border:2px solid #f59e0b}.plan-card-top{justify-content:space-between;align-items:flex-start;display:flex}.plan-icon-wrap{border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.plan-badge{white-space:nowrap;border-radius:20px;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.plan-name{color:#0f172a;font-size:17px;font-weight:600}.plan-price{color:#0f172a;font-size:26px;font-weight:700;line-height:1}.plan-price span{color:#999;font-size:13px;font-weight:400}.plan-meta-row{flex-direction:column;gap:8px;display:flex}.plan-meta-item{color:var(--sidebar-text);align-items:center;gap:7px;font-size:13px;display:flex}.plan-meta-item svg{color:#aaa;flex-shrink:0}.plan-meta-item span{flex:1}.plan-meta-item strong{color:#0f172a;font-weight:600}.plan-progress-wrap{flex-direction:column;gap:5px;display:flex}.plan-progress-label{color:#999;justify-content:space-between;font-size:11.5px;display:flex}.plan-progress-bar{background:#f1f1ee;border-radius:99px;height:5px;overflow:hidden}.plan-progress-bar div{border-radius:99px;height:100%}.plan-actions{border-top:1px solid #f0f0ed;align-items:center;gap:8px;margin-top:2px;padding-top:4px;display:flex}.plan-edit-btn{color:#0f172a;cursor:pointer;background:#f7f7f5;border:1px solid #e8e8e4;border-radius:9px;flex:1;justify-content:center;align-items:center;gap:6px;padding:8px 14px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;transition:all .12s;display:flex}.plan-edit-btn:hover{background:#eeeeed}@keyframes loader-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loader{animation:1s linear infinite loader-spin}.dash-kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:24px;display:grid}.kpi-card{background:#fff;border:1px solid #e8e8e4;border-radius:14px;flex-direction:column;gap:10px;padding:20px;display:flex}.kpi-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.kpi-label{color:#999;letter-spacing:.02em;font-size:12px;font-weight:500}.kpi-value{color:#0f172a;font-size:28px;font-weight:700;line-height:1}.kpi-trend{color:#10b981;align-items:center;gap:3px;font-size:11.5px;display:flex}.kpi-trend.down{color:#ef4444}.dash-lower{grid-template-columns:1fr 1fr;gap:16px;display:grid}.dash-card{background:#fff;border:1px solid #e8e8e4;border-radius:14px;overflow:hidden}.dash-card-header{border-bottom:1px solid #f0f0ed;justify-content:space-between;align-items:center;padding:16px 18px 14px;display:flex}.dash-card-title{color:#0f172a;font-size:14px;font-weight:600}.dash-card-link{color:#0f172a;cursor:pointer;font-size:12px;text-decoration:none}.dash-card-link:hover{text-decoration:underline}.sub-item{border-bottom:1px solid #f7f7f5;align-items:center;gap:12px;padding:13px 18px;transition:background .1s;display:flex}.sub-item:last-child{border-bottom:none}.sub-item:hover{background:#fafaf9}.sub-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:12px;font-weight:600;display:flex}.sub-info{flex:1}.sub-name{color:#0f172a;font-size:13px;font-weight:500}.sub-plan{color:#999;margin-top:1px;font-size:11.5px}.sub-amount{color:#10b981;font-size:13px;font-weight:600}.mock-item{border-bottom:1px solid #f7f7f5;align-items:center;gap:14px;padding:14px 18px;transition:background .1s;display:flex}.mock-item:last-child{border-bottom:none}.mock-item:hover{background:#fafaf9}.mock-rank{width:28px;height:28px;color:var(--sidebar-text);background:#f1f1ee;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.mock-rank.gold{color:#92400e;background:#fef3c7}.mock-rank.silver{color:#475569;background:#f1f5f9}.mock-rank.bronze{color:#9a3412;background:#fef0e7}.mock-info{flex:1}.mock-name{color:#0f172a;font-size:13px;font-weight:500}.mock-meta{color:#999;margin-top:2px;font-size:11.5px}.mock-rate{flex-direction:column;align-items:flex-end;gap:3px;display:flex}.mock-rate-val{color:#10b981;font-size:14px;font-weight:700}.mock-rate-label{color:#aaa;font-size:10.5px}.mock-bar-wrap{background:#f1f1ee;border-radius:99px;width:60px;height:4px;overflow:hidden}.mock-bar{background:#10b981;border-radius:99px;height:100%}.notif-layout{grid-template-columns:1fr 1fr;align-items:start;gap:20px;display:grid}.notif-compose{background:#fff;border:1px solid #e8e8e4;border-radius:14px;overflow:hidden}.notif-compose-header{border-bottom:1px solid #f0f0ed;align-items:center;gap:10px;padding:16px 20px 14px;display:flex}.notif-compose-icon{background:#eef4fd;border-radius:9px;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.notif-compose-title{color:#0f172a;font-size:14px;font-weight:600}.notif-compose-sub{color:#999;margin-top:1px;font-size:11.5px}.notif-compose-body{flex-direction:column;gap:14px;padding:18px 20px;display:flex}.audience-chips{flex-wrap:wrap;gap:8px;display:flex}.chip{color:var(--sidebar-text);cursor:pointer;background:#f7f7f5;border:none;border-radius:20px;padding:6px 14px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:500;transition:all .12s}.chip.active{color:#fff;background:#0f172a;border-color:#0f172a}.chip:hover:not(.active){background:#eeeeec}.send-btn{color:#fff;cursor:pointer;background:#0f172a;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;width:100%;height:42px;font-family:DM Sans,sans-serif;font-size:13.5px;font-weight:500;transition:background .12s;display:flex}.send-btn:hover{background:var(--primary-hover)}.notif-right{flex-direction:column;gap:16px;display:flex}.phone-preview-wrap{background:#fff;border:1px solid #e8e8e4;border-radius:14px;padding:18px 20px}.phone-preview-title{color:#999;letter-spacing:.05em;text-transform:uppercase;margin-bottom:14px;font-size:12px;font-weight:600}.phone-frame{background:#0f172a;border-radius:28px;width:200px;margin:0 auto;padding:14px 12px;position:relative}.phone-notch{background:var(--primary-hover);border-radius:4px;width:60px;height:8px;margin:0 auto 12px}.phone-screen{background:#f5f5f3;border-radius:16px;min-height:120px;padding:10px}.phone-notif-card{background:#fff;border-radius:12px;padding:10px 12px;box-shadow:0 2px 8px #00000014}.phone-notif-app{align-items:center;gap:7px;margin-bottom:7px;display:flex}.phone-app-icon{color:#fff;background:#0f172a;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;font-size:9px;font-weight:700;display:flex}.phone-app-name{color:#888;font-size:10px;font-weight:600}.phone-notif-title{color:#0f172a;word-break:break-word;margin-bottom:3px;font-size:11px;font-weight:700}.phone-notif-body{color:#666;word-break:break-word;font-size:10px;line-height:1.4}.broadcasts-card{background:#fff;border:1px solid #e8e8e4;border-radius:14px;overflow:hidden}.broadcasts-header{border-bottom:1px solid #f0f0ed;justify-content:space-between;align-items:center;padding:16px 20px 14px;display:flex}.broadcast-item{border-bottom:1px solid #f7f7f5;padding:14px 20px;transition:background .1s}.broadcast-item:last-child{border-bottom:none}.broadcast-item:hover{background:#fafaf9}.broadcast-top{justify-content:space-between;align-items:center;margin-bottom:5px;display:flex}.broadcast-sent{color:#065f46;background:#ecfdf5;border-radius:20px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-flex}.broadcast-time{color:#bbb;font-size:11px}.broadcast-title{color:#0f172a;margin-bottom:3px;font-size:13px;font-weight:600}.broadcast-body{color:#888;white-space:nowrap;text-overflow:ellipsis;font-size:12px;line-height:1.5;overflow:hidden}.settings-layout{grid-template-columns:200px 1fr;align-items:start;gap:20px;display:grid}.settings-sidenav{background:#fff;border:1px solid #e8e8e4;border-radius:14px;padding:6px 0;overflow:hidden}.settings-nav-item{color:var(--sidebar-text);cursor:pointer;border-left:2.5px solid #0000;align-items:center;gap:10px;padding:10px 16px;font-size:13px;text-decoration:none;transition:all .12s;display:flex}.settings-nav-item:hover{color:var(--primary-color);background:#f8f8f6}.settings-nav-item.active{color:var(--primary-color);border-left-color:var(--primary-color);background:#f0f0ed;font-weight:500}.settings-nav-item svg{opacity:.55;flex-shrink:0}.settings-nav-item.active svg{opacity:1}.settings-content{flex-direction:column;gap:16px;display:flex}.settings-panel{background:#fff;border:1px solid #e8e8e4;border-radius:14px;overflow:hidden}.settings-panel-header{border-bottom:1px solid #f0f0ed;justify-content:space-between;align-items:flex-start;padding:20px 24px 16px;display:flex}.settings-panel-name{color:var(--primary-color);margin-bottom:3px;font-size:16px;font-weight:600}.settings-panel-sub{color:#999;font-size:12.5px}.settings-panel-actions{align-items:center;gap:12px;display:flex}.settings-view-link{color:var(--primary-color);cursor:pointer;align-items:center;gap:4px;font-size:12.5px;text-decoration:none;display:flex}.settings-view-link:hover{text-decoration:underline}.big-toggle-wrap{position:relative}.big-toggle-wrap input{opacity:0;width:0;height:0;position:absolute}.big-toggle-track{cursor:pointer;background:#d1d5db;border-radius:14px;width:48px;height:28px;transition:background .2s;display:block;position:relative}.big-toggle-track:after{content:"";background:#fff;border-radius:50%;width:22px;height:22px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 4px #0000002e}.big-toggle-wrap input:checked+.big-toggle-track{background:#0f172a}.big-toggle-wrap input:checked+.big-toggle-track:after{transform:translate(20px)}.settings-panel-body{flex-direction:column;gap:20px;padding:24px;display:flex}.settings-field-row{flex-direction:column;gap:6px;display:flex}.settings-field-label{color:#444;font-size:12.5px;font-weight:500}.settings-field-label span{color:#e24b4a;margin-left:2px}.settings-input{color:#0f172a;background:#fafafa;border:1px solid #e8e8e4;border-radius:10px;outline:none;width:100%;height:44px;padding:0 14px;font-family:DM Sans,sans-serif;font-size:13.5px;transition:border-color .12s,background .12s}.settings-input:focus{background:#fff;border-color:#94a3b8;box-shadow:0 0 0 3px #94a3b826}.settings-textarea{color:#0f172a;resize:vertical;background:#fafafa;border:1px solid #e8e8e4;border-radius:10px;outline:none;width:100%;min-height:80px;padding:12px 14px;font-family:DM Sans,sans-serif;font-size:13.5px;line-height:1.6;transition:border-color .12s,background .12s}.settings-textarea:focus{background:#fff;border-color:#94a3b8;box-shadow:0 0 0 3px #94a3b826}.settings-two-col{grid-template-columns:1fr 1fr;gap:16px;display:grid}.settings-footer{border-top:1px solid #f0f0ed;gap:10px;padding:18px 24px;display:flex}.btn-save-settings{color:#fff;cursor:pointer;background:#0f172a;border:none;border-radius:9px;flex:1;height:40px;font-family:DM Sans,sans-serif;font-size:13.5px;font-weight:500;transition:background .12s}.btn-save-settings:hover{background:var(--primary-hover)}.btn-reset{height:40px;color:var(--sidebar-text);cursor:pointer;background:#fff;border:1px solid #e8e8e4;border-radius:9px;flex:1;padding:0 20px;font-family:DM Sans,sans-serif;font-size:13.5px;font-weight:500;transition:all .12s}.btn-reset:hover{color:#0f172a;background:#f7f7f5;border-color:#d1d5db}.btn-reset:disabled{opacity:.6;cursor:not-allowed}.gen-section{flex-direction:column;gap:20px;display:flex}.gen-row{border-bottom:1px solid #f7f7f5;justify-content:space-between;align-items:center;padding:14px 0;display:flex}.gen-row:last-child{border-bottom:none}.gen-row-info strong{color:#0f172a;margin-bottom:2px;font-size:13.5px;font-weight:500;display:block}.gen-row-info span{color:#999;font-size:12px}#page-broadcasts{flex-direction:column;gap:0;min-height:100%;padding:0;display:flex}.stats-row{gap:16px;margin-bottom:24px;display:grid}.stat-card{background:#fff;border:1px solid #e8e8e4;border-radius:14px;padding:20px 24px}.stat-label{color:#999;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:12px;font-weight:500}.stat-val{color:#0f172a;align-items:baseline;gap:4px;font-size:24px;font-weight:600;display:flex}.stat-val .unit{color:#999;font-size:13px;font-weight:400}.table-card{background:#fff;border:1px solid #e8e8e4;border-radius:14px;flex-direction:column;display:flex;overflow:hidden}.toolbar{border-bottom:1px solid #f0f0ed;justify-content:space-between;align-items:center;gap:16px;padding:16px 20px;display:flex}.search-box{background:#f8f8f6;border:1px solid #e8e8e4;border-radius:9px;flex:1;align-items:center;gap:10px;max-width:320px;height:36px;padding:0 12px;display:flex;position:relative}.search-box svg{color:#aaa}.search-box input{color:#0f172a;background:0 0;border:none;outline:none;width:100%;font-family:DM Sans,sans-serif;font-size:13px}.filter-select{height:36px;color:var(--sidebar-text);cursor:pointer;background:#fff;border:1px solid #e8e8e4;border-radius:9px;align-items:center;gap:8px;padding:0 12px;font-size:13px;display:flex;position:relative}.filter-select select{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;top:0;left:0}table{border-collapse:collapse;width:100%}th{text-align:left;color:#999;text-transform:uppercase;letter-spacing:.05em;background:#fafafa;border-bottom:1px solid #f0f0ed;padding:14px 20px;font-size:11.5px;font-weight:600}td{vertical-align:middle;border-bottom:1px solid #f0f0ed;padding:16px 20px}tr:last-child td{border-bottom:none}.table-footer{background:#fafafa;border-top:1px solid #f0f0ed;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.table-footer span{color:#999;font-size:12.5px}.pagination{gap:6px;display:flex}.pg-btn{width:30px;height:30px;color:var(--sidebar-text);cursor:pointer;background:#fff;border:1px solid #e8e8e4;border-radius:6px;justify-content:center;align-items:center;font-size:13px;transition:all .12s;display:flex}.pg-btn:hover{color:#0f172a;background:#f8f8f6}.pg-btn.active{color:#fff;background:#0f172a;border-color:#0f172a}.btn-upload-label{background:var(--primary-color);color:#fff;cursor:pointer;border-radius:9px;align-items:center;gap:8px;padding:8px 18px;font-size:13.5px;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-flex}.btn-upload-label:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.banner-empty-state{text-align:center;color:#999;background:#fafafa;border:1px dashed #e8e8e4;border-radius:14px;padding:80px 40px}.banner-empty-icon{color:#d1d5db;margin-bottom:16px}.banner-empty-title{color:#0f172a;margin-bottom:4px;font-size:15px;font-weight:600}.banner-empty-sub{opacity:.8;font-size:12.5px}.banners-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px;display:grid}.banner-item-card{background:#fff;border:1px solid #e8e8e4;border-radius:14px;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.banner-item-card:hover{border-color:#d1d5db;transform:translateY(-4px);box-shadow:0 12px 24px #0000000f}.banner-preview-wrap{aspect-ratio:2/.9;background:#f8f8f6;position:relative;overflow:hidden}.banner-preview-wrap img{object-fit:cover;width:100%;height:100%}.banner-overlay{opacity:0;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a66;justify-content:center;align-items:center;transition:all .25s;display:flex;position:absolute;inset:0}.banner-item-card:hover .banner-overlay{opacity:1}.banner-delete-btn{color:#fff;cursor:pointer;background:#ff4d4f;border:none;border-radius:12px;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s cubic-bezier(.34,1.56,.64,1);display:flex;box-shadow:0 4px 12px #ff4d4f4d}.banner-delete-btn:hover{background:#ff7875;transform:scale(1.1)rotate(5deg)}.banner-item-info{background:#fafafa;border-top:1px solid #f0f0ed;padding:14px 20px}.banner-date{color:#999;text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:600}.ql-container{box-sizing:border-box;height:100%;margin:0;font-family:Helvetica,Arial,sans-serif;font-size:13px;position:relative}.ql-container.ql-disabled .ql-tooltip{visibility:hidden}.ql-container:not(.ql-disabled) li[data-list=checked]>.ql-ui,.ql-container:not(.ql-disabled) li[data-list=unchecked]>.ql-ui{cursor:pointer}.ql-clipboard{height:1px;position:absolute;top:50%;left:-100000px;overflow-y:hidden}.ql-clipboard p{margin:0;padding:0}.ql-editor{box-sizing:border-box;counter-reset:list-0 list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9;tab-size:4;text-align:left;white-space:pre-wrap;word-wrap:break-word;outline:none;height:100%;padding:12px 15px;line-height:1.42;overflow-y:auto}.ql-editor>*{cursor:text}.ql-editor p,.ql-editor ol,.ql-editor pre,.ql-editor blockquote,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6{margin:0;padding:0}@supports (counter-set:none){.ql-editor p,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6{counter-set:list-0 list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor p,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6{counter-reset:list-0 list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor table{border-collapse:collapse}.ql-editor td{border:1px solid #000;padding:2px 5px}.ql-editor ol{padding-left:1.5em}.ql-editor li{padding-left:1.5em;list-style-type:none;position:relative}.ql-editor li>.ql-ui:before{text-align:right;white-space:nowrap;width:1.2em;margin-left:-1.5em;margin-right:.3em;display:inline-block}.ql-editor li[data-list=checked]>.ql-ui,.ql-editor li[data-list=unchecked]>.ql-ui{color:#777}.ql-editor li[data-list=bullet]>.ql-ui:before{content:"•"}.ql-editor li[data-list=checked]>.ql-ui:before{content:"☑"}.ql-editor li[data-list=unchecked]>.ql-ui:before{content:"☐"}@supports (counter-set:none){.ql-editor li[data-list]{counter-set:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list]{counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered]{counter-increment:list-0}.ql-editor li[data-list=ordered]>.ql-ui:before{content:counter(list-0, decimal) ". "}.ql-editor li[data-list=ordered].ql-indent-1{counter-increment:list-1}.ql-editor li[data-list=ordered].ql-indent-1>.ql-ui:before{content:counter(list-1, lower-alpha) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-1{counter-set:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-1{counter-reset:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-2{counter-increment:list-2}.ql-editor li[data-list=ordered].ql-indent-2>.ql-ui:before{content:counter(list-2, lower-roman) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-2{counter-set:list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-2{counter-reset:list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-3{counter-increment:list-3}.ql-editor li[data-list=ordered].ql-indent-3>.ql-ui:before{content:counter(list-3, decimal) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-3{counter-set:list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-3{counter-reset:list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-4{counter-increment:list-4}.ql-editor li[data-list=ordered].ql-indent-4>.ql-ui:before{content:counter(list-4, lower-alpha) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-4{counter-set:list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-4{counter-reset:list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-5{counter-increment:list-5}.ql-editor li[data-list=ordered].ql-indent-5>.ql-ui:before{content:counter(list-5, lower-roman) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-5{counter-set:list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-5{counter-reset:list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-6{counter-increment:list-6}.ql-editor li[data-list=ordered].ql-indent-6>.ql-ui:before{content:counter(list-6, decimal) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-6{counter-set:list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-6{counter-reset:list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-7{counter-increment:list-7}.ql-editor li[data-list=ordered].ql-indent-7>.ql-ui:before{content:counter(list-7, lower-alpha) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-7{counter-set:list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-7{counter-reset:list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-8{counter-increment:list-8}.ql-editor li[data-list=ordered].ql-indent-8>.ql-ui:before{content:counter(list-8, lower-roman) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-8{counter-set:list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-8{counter-reset:list-9}}.ql-editor li[data-list=ordered].ql-indent-9{counter-increment:list-9}.ql-editor li[data-list=ordered].ql-indent-9>.ql-ui:before{content:counter(list-9, decimal) ". "}.ql-editor .ql-indent-1:not(.ql-direction-rtl){padding-left:3em}.ql-editor li.ql-indent-1:not(.ql-direction-rtl){padding-left:4.5em}.ql-editor .ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:3em}.ql-editor li.ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:4.5em}.ql-editor .ql-indent-2:not(.ql-direction-rtl){padding-left:6em}.ql-editor li.ql-indent-2:not(.ql-direction-rtl){padding-left:7.5em}.ql-editor .ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:6em}.ql-editor li.ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:7.5em}.ql-editor .ql-indent-3:not(.ql-direction-rtl){padding-left:9em}.ql-editor li.ql-indent-3:not(.ql-direction-rtl){padding-left:10.5em}.ql-editor .ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:9em}.ql-editor li.ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:10.5em}.ql-editor .ql-indent-4:not(.ql-direction-rtl){padding-left:12em}.ql-editor li.ql-indent-4:not(.ql-direction-rtl){padding-left:13.5em}.ql-editor .ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:12em}.ql-editor li.ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:13.5em}.ql-editor .ql-indent-5:not(.ql-direction-rtl){padding-left:15em}.ql-editor li.ql-indent-5:not(.ql-direction-rtl){padding-left:16.5em}.ql-editor .ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:15em}.ql-editor li.ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:16.5em}.ql-editor .ql-indent-6:not(.ql-direction-rtl){padding-left:18em}.ql-editor li.ql-indent-6:not(.ql-direction-rtl){padding-left:19.5em}.ql-editor .ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:18em}.ql-editor li.ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:19.5em}.ql-editor .ql-indent-7:not(.ql-direction-rtl){padding-left:21em}.ql-editor li.ql-indent-7:not(.ql-direction-rtl){padding-left:22.5em}.ql-editor .ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:21em}.ql-editor li.ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:22.5em}.ql-editor .ql-indent-8:not(.ql-direction-rtl){padding-left:24em}.ql-editor li.ql-indent-8:not(.ql-direction-rtl){padding-left:25.5em}.ql-editor .ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:24em}.ql-editor li.ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:25.5em}.ql-editor .ql-indent-9:not(.ql-direction-rtl){padding-left:27em}.ql-editor li.ql-indent-9:not(.ql-direction-rtl){padding-left:28.5em}.ql-editor .ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:27em}.ql-editor li.ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:28.5em}.ql-editor li.ql-direction-rtl{padding-right:1.5em}.ql-editor li.ql-direction-rtl>.ql-ui:before{text-align:left;margin-left:.3em;margin-right:-1.5em}.ql-editor table{table-layout:fixed;width:100%}.ql-editor table td{outline:none}.ql-editor .ql-code-block-container{font-family:monospace}.ql-editor .ql-video{max-width:100%;display:block}.ql-editor .ql-video.ql-align-center{margin:0 auto}.ql-editor .ql-video.ql-align-right{margin:0 0 0 auto}.ql-editor .ql-bg-black{background-color:#000}.ql-editor .ql-bg-red{background-color:#e60000}.ql-editor .ql-bg-orange{background-color:#f90}.ql-editor .ql-bg-yellow{background-color:#ff0}.ql-editor .ql-bg-green{background-color:#008a00}.ql-editor .ql-bg-blue{background-color:#06c}.ql-editor .ql-bg-purple{background-color:#93f}.ql-editor .ql-color-white{color:#fff}.ql-editor .ql-color-red{color:#e60000}.ql-editor .ql-color-orange{color:#f90}.ql-editor .ql-color-yellow{color:#ff0}.ql-editor .ql-color-green{color:#008a00}.ql-editor .ql-color-blue{color:#06c}.ql-editor .ql-color-purple{color:#93f}.ql-editor .ql-font-serif{font-family:Georgia,Times New Roman,serif}.ql-editor .ql-font-monospace{font-family:Monaco,Courier New,monospace}.ql-editor .ql-size-small{font-size:.75em}.ql-editor .ql-size-large{font-size:1.5em}.ql-editor .ql-size-huge{font-size:2.5em}.ql-editor .ql-direction-rtl{text-align:inherit;direction:rtl}.ql-editor .ql-align-center{text-align:center}.ql-editor .ql-align-justify{text-align:justify}.ql-editor .ql-align-right{text-align:right}.ql-editor .ql-ui{position:absolute}.ql-editor.ql-blank:before{color:#0009;content:attr(data-placeholder);pointer-events:none;font-style:italic;position:absolute;left:15px;right:15px}.ql-snow.ql-toolbar:after,.ql-snow .ql-toolbar:after{clear:both;content:"";display:table}.ql-snow.ql-toolbar button,.ql-snow .ql-toolbar button{cursor:pointer;float:left;background:0 0;border:none;width:28px;height:24px;padding:3px 5px;display:inline-block}.ql-snow.ql-toolbar button svg,.ql-snow .ql-toolbar button svg{float:left;height:100%}.ql-snow.ql-toolbar button:active:hover,.ql-snow .ql-toolbar button:active:hover{outline:none}.ql-snow.ql-toolbar input.ql-image[type=file],.ql-snow .ql-toolbar input.ql-image[type=file]{display:none}.ql-snow.ql-toolbar button:hover,.ql-snow .ql-toolbar button:hover,.ql-snow.ql-toolbar button:focus,.ql-snow .ql-toolbar button:focus,.ql-snow.ql-toolbar button.ql-active,.ql-snow .ql-toolbar button.ql-active,.ql-snow.ql-toolbar .ql-picker-label:hover,.ql-snow .ql-toolbar .ql-picker-label:hover,.ql-snow.ql-toolbar .ql-picker-label.ql-active,.ql-snow .ql-toolbar .ql-picker-label.ql-active,.ql-snow.ql-toolbar .ql-picker-item:hover,.ql-snow .ql-toolbar .ql-picker-item:hover,.ql-snow.ql-toolbar .ql-picker-item.ql-selected,.ql-snow .ql-toolbar .ql-picker-item.ql-selected{color:#06c}.ql-snow.ql-toolbar button:hover .ql-fill,.ql-snow .ql-toolbar button:hover .ql-fill,.ql-snow.ql-toolbar button:focus .ql-fill,.ql-snow .ql-toolbar button:focus .ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow.ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill{fill:#06c}.ql-snow.ql-toolbar button:hover .ql-stroke,.ql-snow .ql-toolbar button:hover .ql-stroke,.ql-snow.ql-toolbar button:focus .ql-stroke,.ql-snow .ql-toolbar button:focus .ql-stroke,.ql-snow.ql-toolbar button.ql-active .ql-stroke,.ql-snow .ql-toolbar button.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow.ql-toolbar button:hover .ql-stroke-miter,.ql-snow .ql-toolbar button:hover .ql-stroke-miter,.ql-snow.ql-toolbar button:focus .ql-stroke-miter,.ql-snow .ql-toolbar button:focus .ql-stroke-miter,.ql-snow.ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter{stroke:#06c}@media (pointer:coarse){.ql-snow.ql-toolbar button:hover:not(.ql-active),.ql-snow .ql-toolbar button:hover:not(.ql-active){color:#444}.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill{fill:#444}.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter{stroke:#444}}.ql-snow,.ql-snow *{box-sizing:border-box}.ql-snow .ql-hidden{display:none}.ql-snow .ql-out-bottom,.ql-snow .ql-out-top{visibility:hidden}.ql-snow .ql-tooltip{position:absolute;transform:translateY(10px)}.ql-snow .ql-tooltip a{cursor:pointer;text-decoration:none}.ql-snow .ql-tooltip.ql-flip{transform:translateY(-10px)}.ql-snow .ql-formats{vertical-align:middle;display:inline-block}.ql-snow .ql-formats:after{clear:both;content:"";display:table}.ql-snow .ql-stroke{fill:none;stroke:#444;stroke-linecap:round;stroke-linejoin:round;stroke-width:2px}.ql-snow .ql-stroke-miter{fill:none;stroke:#444;stroke-miterlimit:10;stroke-width:2px}.ql-snow .ql-fill,.ql-snow .ql-stroke.ql-fill{fill:#444}.ql-snow .ql-empty{fill:none}.ql-snow .ql-even{fill-rule:evenodd}.ql-snow .ql-thin,.ql-snow .ql-stroke.ql-thin{stroke-width:1px}.ql-snow .ql-transparent{opacity:.4}.ql-snow .ql-direction svg:last-child{display:none}.ql-snow .ql-direction.ql-active svg:last-child{display:inline}.ql-snow .ql-direction.ql-active svg:first-child{display:none}.ql-snow .ql-editor h1{font-size:2em}.ql-snow .ql-editor h2{font-size:1.5em}.ql-snow .ql-editor h3{font-size:1.17em}.ql-snow .ql-editor h4{font-size:1em}.ql-snow .ql-editor h5{font-size:.83em}.ql-snow .ql-editor h6{font-size:.67em}.ql-snow .ql-editor a{text-decoration:underline}.ql-snow .ql-editor blockquote{border-left:4px solid #ccc;margin-top:5px;margin-bottom:5px;padding-left:16px}.ql-snow .ql-editor code,.ql-snow .ql-editor .ql-code-block-container{background-color:#f0f0f0;border-radius:3px}.ql-snow .ql-editor .ql-code-block-container{margin-top:5px;margin-bottom:5px;padding:5px 10px}.ql-snow .ql-editor code{padding:2px 4px;font-size:85%}.ql-snow .ql-editor .ql-code-block-container{color:#f8f8f2;background-color:#23241f;overflow:visible}.ql-snow .ql-editor img{max-width:100%}.ql-snow .ql-picker{color:#444;float:left;vertical-align:middle;height:24px;font-size:14px;font-weight:500;display:inline-block;position:relative}.ql-snow .ql-picker-label{cursor:pointer;width:100%;height:100%;padding-left:8px;padding-right:2px;display:inline-block;position:relative}.ql-snow .ql-picker-label:before{line-height:22px;display:inline-block}.ql-snow .ql-picker-options{white-space:nowrap;background-color:#fff;min-width:100%;padding:4px 8px;display:none;position:absolute}.ql-snow .ql-picker-options .ql-picker-item{cursor:pointer;padding-top:5px;padding-bottom:5px;display:block}.ql-snow .ql-picker.ql-expanded .ql-picker-label{color:#ccc;z-index:2}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-fill{fill:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-stroke{stroke:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-options{z-index:1;margin-top:-1px;display:block;top:100%}.ql-snow .ql-color-picker,.ql-snow .ql-icon-picker{width:28px}.ql-snow .ql-color-picker .ql-picker-label,.ql-snow .ql-icon-picker .ql-picker-label{padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-label svg,.ql-snow .ql-icon-picker .ql-picker-label svg{right:4px}.ql-snow .ql-icon-picker .ql-picker-options{padding:4px 0}.ql-snow .ql-icon-picker .ql-picker-item{width:24px;height:24px;padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-options{width:152px;padding:3px 5px}.ql-snow .ql-color-picker .ql-picker-item{float:left;border:1px solid #0000;width:16px;height:16px;margin:2px;padding:0}.ql-snow .ql-picker:not(.ql-color-picker):not(.ql-icon-picker) svg{width:18px;margin-top:-9px;position:absolute;top:50%;right:0}.ql-snow .ql-picker.ql-header .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-label]:not([data-label=""]):before{content:attr(data-label)}.ql-snow .ql-picker.ql-header{width:98px}.ql-snow .ql-picker.ql-header .ql-picker-label:before,.ql-snow .ql-picker.ql-header .ql-picker-item:before{content:"Normal"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="1"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{content:"Heading 1"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{content:"Heading 2"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{content:"Heading 3"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="4"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{content:"Heading 4"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="5"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{content:"Heading 5"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="6"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{content:"Heading 6"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{font-size:2em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{font-size:1.5em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{font-size:1.17em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{font-size:1em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{font-size:.83em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{font-size:.67em}.ql-snow .ql-picker.ql-font{width:108px}.ql-snow .ql-picker.ql-font .ql-picker-label:before,.ql-snow .ql-picker.ql-font .ql-picker-item:before{content:"Sans Serif"}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=serif]:before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{content:"Serif"}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=monospace]:before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{content:"Monospace"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{font-family:Georgia,Times New Roman,serif}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{font-family:Monaco,Courier New,monospace}.ql-snow .ql-picker.ql-size{width:98px}.ql-snow .ql-picker.ql-size .ql-picker-label:before,.ql-snow .ql-picker.ql-size .ql-picker-item:before{content:"Normal"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=small]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{content:"Small"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=large]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{content:"Large"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=huge]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{content:"Huge"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{font-size:10px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{font-size:18px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{font-size:32px}.ql-snow .ql-color-picker.ql-background .ql-picker-item{background-color:#fff}.ql-snow .ql-color-picker.ql-color .ql-picker-item{background-color:#000}.ql-code-block-container{position:relative}.ql-code-block-container .ql-ui{top:5px;right:5px}.ql-toolbar.ql-snow{box-sizing:border-box;border:1px solid #ccc;padding:8px;font-family:Helvetica Neue,Helvetica,Arial,sans-serif}.ql-toolbar.ql-snow .ql-formats{margin-right:15px}.ql-toolbar.ql-snow .ql-picker-label{border:1px solid #0000}.ql-toolbar.ql-snow .ql-picker-options{border:1px solid #0000;box-shadow:0 2px 8px #0003}.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label,.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-options{border-color:#ccc}.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item.ql-selected,.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item:hover{border-color:#000}.ql-toolbar.ql-snow+.ql-container.ql-snow{border-top:0}.ql-snow .ql-tooltip{color:#444;white-space:nowrap;background-color:#fff;border:1px solid #ccc;padding:5px 12px;box-shadow:0 0 5px #ddd}.ql-snow .ql-tooltip:before{content:"Visit URL:";margin-right:8px;line-height:26px}.ql-snow .ql-tooltip input[type=text]{border:1px solid #ccc;width:170px;height:26px;margin:0;padding:3px 5px;font-size:13px;display:none}.ql-snow .ql-tooltip a.ql-preview{text-overflow:ellipsis;vertical-align:top;max-width:200px;display:inline-block;overflow-x:hidden}.ql-snow .ql-tooltip a.ql-action:after{content:"Edit";border-right:1px solid #ccc;margin-left:16px;padding-right:8px}.ql-snow .ql-tooltip a.ql-remove:before{content:"Remove";margin-left:8px}.ql-snow .ql-tooltip a{line-height:26px}.ql-snow .ql-tooltip.ql-editing a.ql-preview,.ql-snow .ql-tooltip.ql-editing a.ql-remove{display:none}.ql-snow .ql-tooltip.ql-editing input[type=text]{display:inline-block}.ql-snow .ql-tooltip.ql-editing a.ql-action:after{content:"Save";border-right:0;padding-right:0}.ql-snow .ql-tooltip[data-mode=link]:before{content:"Enter link:"}.ql-snow .ql-tooltip[data-mode=formula]:before{content:"Enter formula:"}.ql-snow .ql-tooltip[data-mode=video]:before{content:"Enter video:"}.ql-snow a{color:#06c}.ql-container.ql-snow{border:1px solid #ccc}.counter{color:var(--accent);background:var(--accent-bg);border:2px solid #0000;border-radius:5px;margin-bottom:24px;padding:5px 10px;font-size:16px;transition:border-color .3s}.counter:hover{border-color:var(--accent-border)}.counter:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{margin:0 auto;inset-inline:0}.hero .base{z-index:0;width:170px;position:relative}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;height:28px;top:34px;transform:perspective(2000px)rotate(300deg)rotateX(44deg)rotateY(39deg)scale(1.4)}.hero .vite{z-index:0;width:auto;height:26px;top:107px;transform:perspective(2000px)rotate(300deg)rotateX(40deg)rotateY(39deg)scale(.8)}#center{flex-direction:column;flex-grow:1;place-content:center;place-items:center;gap:25px;display:flex}@media (width<=1024px){#center{gap:18px;padding:32px 20px 24px}}#next-steps{border-top:1px solid var(--border);text-align:left;display:flex}#next-steps>div{flex:1 1 0;padding:32px}@media (width<=1024px){#next-steps>div{padding:24px 20px}}#next-steps .icon{width:22px;height:22px;margin-bottom:16px}@media (width<=1024px){#next-steps{text-align:center;flex-direction:column}}#docs{border-right:1px solid var(--border)}@media (width<=1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{gap:8px;margin:32px 0 0;padding:0;list-style:none;display:flex}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);background:var(--social-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:16px;text-decoration:none;transition:box-shadow .3s;display:flex}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{width:18px;height:18px}@media (width<=1024px){#next-steps ul{flex-wrap:wrap;justify-content:center;margin-top:20px}#next-steps ul li{flex:calc(50% - 8px)}#next-steps ul a{box-sizing:border-box;justify-content:center;width:100%}}#spacer{border-top:1px solid var(--border);height:88px}@media (width<=1024px){#spacer{height:48px}}.ticks{width:100%;position:relative}.ticks:before,.ticks:after{content:"";border:5px solid #0000;position:absolute;top:-4.5px}.ticks:before{border-left-color:var(--border);left:0}.ticks:after{border-right-color:var(--border);right:0}
