*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--green: #52AE32;--green-hover: #469E2A;--green-dim: rgba(82,174,50,.1);--green-dim2: rgba(82,174,50,.06);--orange: #FF8C29;--orange-dim: rgba(255,140,41,.1);--text: #3D3D3C;--text2: #6B7280;--text3: #9CA3AF;--bg: #FFFFFF;--bg2: #F7F8FA;--bg3: #F0F2F5;--border: rgba(61,61,60,.1);--border2: rgba(61,61,60,.06);--radius: 10px;--radius-lg: 14px}html,body{font-family:Rubik,sans-serif;background:var(--bg2);color:var(--text);min-height:100vh}#root{min-height:100vh}.tab-nav-wrap{background:var(--bg);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.tab-nav{display:flex;justify-content:center;gap:0;max-width:1100px;margin:0 auto;padding:0 24px}.tab-nav-item{display:flex;align-items:center;gap:7px;padding:16px 22px;font-size:14px;font-weight:500;color:var(--text2);cursor:pointer;border-bottom:2.5px solid transparent;transition:all .15s;white-space:nowrap;-webkit-user-select:none;user-select:none;background:none;border-left:none;border-right:none;border-top:none;font-family:Rubik,sans-serif}.tab-nav-item:hover{color:var(--text)}.tab-nav-item.active{color:var(--green);border-bottom-color:var(--green);font-weight:600}.tab-nav-item svg{width:15px;height:15px;flex-shrink:0}.tab-badge{background:var(--orange);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:20px;line-height:1.4}.content-wrap{max-width:1100px;margin:0 auto;padding:28px 24px 48px}.page{display:none}.page.active{display:block;animation:fadeIn .18s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;border-radius:var(--radius);cursor:pointer;border:1.5px solid transparent;transition:all .15s;font-family:Rubik,sans-serif;background:none}.btn-primary{background:var(--green);color:#fff;border-color:var(--green)}.btn-primary:hover{background:var(--green-hover);border-color:var(--green-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-ghost{background:transparent;color:var(--text2);border-color:var(--border)}.btn-ghost:hover{background:var(--bg2);color:var(--text);border-color:#3d3d3c33}.btn-ghost:disabled{opacity:.6;cursor:not-allowed}.btn-sm{padding:5px 12px;font-size:12px}.catalog-hero{background:var(--text);border-radius:var(--radius-lg);padding:28px 32px;margin-bottom:24px;position:relative;overflow:hidden}.catalog-hero:before{content:"";position:absolute;right:-30px;top:-30px;width:200px;height:200px;background:var(--green);opacity:.12;border-radius:50%}.catalog-hero:after{content:"";position:absolute;right:70px;top:30px;width:110px;height:110px;background:var(--orange);opacity:.1;border-radius:50%}.catalog-hero h1{font-size:22px;font-weight:700;color:#fff;margin-bottom:8px;letter-spacing:-.01em}.catalog-hero p{font-size:13px;color:#ffffffa6;max-width:500px;line-height:1.65}.catalog-hero-actions{margin-top:20px;display:flex;gap:10px}.btn-hero-primary{background:var(--green);color:#fff;border-color:var(--green)}.btn-hero-primary:hover{background:var(--green-hover)}.btn-hero-ghost{background:transparent;color:#ffffffb3;border-color:#ffffff40}.btn-hero-ghost:hover{background:#ffffff12;color:#fff}.catalog-filters{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap;align-items:center}.filter-pill{padding:6px 15px;font-size:12px;font-weight:500;border-radius:20px;border:1.5px solid var(--border);cursor:pointer;transition:all .15s;color:var(--text2);background:var(--bg);font-family:Rubik,sans-serif}.filter-pill:hover{border-color:var(--green);color:var(--green)}.filter-pill.active{background:var(--green-dim);border-color:var(--green);color:var(--green)}.catalog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.report-card{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:20px;cursor:pointer;transition:all .2s;position:relative;overflow:hidden}.report-card:hover{border-color:var(--green);box-shadow:0 6px 24px #52ae321f;transform:translateY(-2px)}.report-card:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:transparent;transition:background .2s;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.report-card:hover:after{background:var(--green)}.rc-icon{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;margin-bottom:14px;font-size:19px}.rc-icon.green{background:var(--green-dim)}.rc-icon.orange{background:var(--orange-dim)}.rc-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:6px}.rc-desc{font-size:12px;color:var(--text2);line-height:1.65;margin-bottom:14px}.rc-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.tag{display:inline-flex;align-items:center;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:500}.tag-green{background:var(--green-dim);color:var(--green)}.tag-orange{background:var(--orange-dim);color:var(--orange)}.tag-gray{background:var(--bg3);color:var(--text3)}.rc-arrow{margin-left:auto;color:var(--text3);font-size:16px;transition:transform .2s;flex-shrink:0}.report-card:hover .rc-arrow{transform:translate(3px);color:var(--green)}.card-hot{position:absolute;top:13px;right:13px;background:var(--orange);color:#fff;font-size:10px;font-weight:700;padding:3px 9px;border-radius:20px}.card-new{position:absolute;top:13px;right:13px;background:var(--green);color:#fff;font-size:10px;font-weight:700;padding:3px 9px;border-radius:20px}.constructor-layout{display:grid;grid-template-columns:272px 1fr;gap:20px;align-items:start}.steps-sidebar{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;position:sticky;top:72px}.steps-progress{height:3px;background:var(--bg3)}.steps-progress-fill{height:100%;background:var(--green);transition:width .3s ease;border-radius:0 2px 2px 0}.step-item{display:flex;align-items:center;gap:12px;padding:13px 18px;cursor:pointer;border-left:3px solid transparent;transition:all .15s}.step-item:hover{background:var(--bg2)}.step-item.active{background:var(--green-dim2);border-left-color:var(--green)}.step-item.done{border-left-color:var(--green)}.step-num{width:26px;height:26px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:var(--text3);flex-shrink:0;transition:all .15s}.step-item.active .step-num{background:var(--green);border-color:var(--green);color:#fff}.step-item.done .step-num{background:var(--green);border-color:var(--green);color:#fff;font-size:11px}.step-info{flex:1;min-width:0}.step-label{font-size:12px;font-weight:600;color:var(--text)}.step-item.active .step-label{color:var(--green)}.step-sublabel{font-size:11px;color:var(--text3);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.step-check{color:var(--green);font-size:13px;opacity:0;transition:opacity .15s;flex-shrink:0}.step-item.done .step-check{opacity:1}.constructor-main{display:flex;flex-direction:column;gap:18px}.step-panel{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-lg)}.step-panel-header{padding:17px 22px;border-bottom:1px solid var(--border2);display:flex;align-items:center;gap:12px}.step-num-circle{width:28px;height:28px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}.step-panel-title{font-size:15px;font-weight:600;color:var(--text)}.step-panel-body{padding:22px}.date-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}.form-group{display:flex;flex-direction:column;gap:5px}.form-label{font-size:11px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.05em}.form-input{padding:9px 12px;border:1.5px solid var(--border);border-radius:8px;font-size:13px;font-family:Rubik,sans-serif;color:var(--text);background:var(--bg);outline:none;transition:border-color .15s;width:100%}.form-input:focus{border-color:var(--green)}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='%239CA3AF' d='M4 6l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:16px;padding-right:32px;cursor:pointer}.quick-dates{display:flex;gap:6px;margin-bottom:18px;flex-wrap:wrap}.qd-btn{padding:5px 13px;font-size:12px;font-weight:500;border:1.5px solid var(--border);border-radius:6px;cursor:pointer;color:var(--text2);background:var(--bg2);transition:all .15s;font-family:Rubik,sans-serif}.qd-btn:hover,.qd-btn.active{background:var(--green-dim);border-color:var(--green);color:var(--green)}.filter-section{margin-bottom:16px}.filter-section-title{font-size:12px;font-weight:600;color:var(--text2);margin-bottom:9px}.filter-tags{display:flex;flex-wrap:wrap;gap:6px}.filter-tag{display:inline-flex;align-items:center;gap:4px;padding:5px 11px;background:var(--bg2);border:1.5px solid var(--border);border-radius:6px;font-size:12px;cursor:pointer;transition:all .15s;color:var(--text2);font-family:Rubik,sans-serif}.filter-tag.sel{background:var(--green-dim);border-color:var(--green);color:var(--green);font-weight:500}.filter-tag:hover:not(.sel){border-color:#3d3d3c33;color:var(--text)}.filter-add{padding:5px 11px;background:transparent;border:1.5px dashed var(--border);border-radius:6px;font-size:12px;cursor:pointer;color:var(--text3);font-family:Rubik,sans-serif;transition:all .15s}.filter-add:hover{border-color:var(--green);color:var(--green)}.rt-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.rt-card{border:1.5px solid var(--border);border-radius:var(--radius);padding:16px;cursor:pointer;transition:all .2s}.rt-card:hover{border-color:#3d3d3c40}.rt-card.sel{border-color:var(--green);background:var(--green-dim2)}.rt-icon{font-size:22px;margin-bottom:10px}.rt-name{font-size:13px;font-weight:600;color:var(--text);margin-bottom:4px}.rt-card.sel .rt-name{color:var(--green)}.rt-desc{font-size:11px;color:var(--text2);line-height:1.55}.group-builder{display:flex;flex-direction:column;gap:10px}.group-level{display:flex;align-items:center;gap:10px}.group-level-label{font-size:11px;font-weight:600;color:var(--text3);width:58px;flex-shrink:0}.group-level select{flex:1}.group-chips{display:flex;gap:6px;flex-wrap:wrap;margin-top:14px;align-items:center}.gchip{display:inline-flex;align-items:center;background:var(--green-dim);border:1px solid rgba(82,174,50,.25);color:var(--green);padding:4px 11px;border-radius:6px;font-size:12px;font-weight:500}.arrow-chip{font-size:14px;color:var(--text3)}.cols-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.cols-toggle{display:flex;gap:4px}.cols-toggle-btn{padding:4px 11px;font-size:12px;font-weight:500;border:1.5px solid var(--border);border-radius:6px;cursor:pointer;background:var(--bg2);color:var(--text2);transition:all .15s;font-family:Rubik,sans-serif}.cols-toggle-btn.active{background:var(--text);color:#fff;border-color:var(--text)}.cols-list{display:flex;flex-direction:column;gap:4px}.col-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1.5px solid var(--border);border-radius:8px;background:var(--bg);transition:all .15s;cursor:grab;-webkit-user-select:none;user-select:none}.col-row:hover{border-color:#3d3d3c33}.col-row.drag-over{border-color:var(--green);background:var(--green-dim2)}.col-row.dragging{opacity:.4}.col-drag{color:var(--text3);font-size:13px;cursor:grab}.col-check{width:17px;height:17px;border-radius:4px;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;flex-shrink:0}.col-check.on{background:var(--green);border-color:var(--green)}.col-check.on:after{content:"✓";color:#fff;font-size:10px;font-weight:700}.col-name{flex:1;font-size:13px;font-weight:500;color:var(--text)}.col-type{font-size:11px;color:var(--text3);background:var(--bg3);padding:2px 8px;border-radius:4px;font-family:monospace}.col-sum-badge{background:var(--green-dim);color:var(--green);font-size:10px;font-weight:700;padding:2px 7px;border-radius:4px}.options-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.options-group-title{font-size:12px;font-weight:600;color:var(--text2);margin-bottom:8px}.radio-row{display:flex;align-items:center;gap:8px;padding:9px 12px;border:1.5px solid var(--border);border-radius:8px;cursor:pointer;transition:all .15s;margin-bottom:6px}.radio-row:hover{border-color:#3d3d3c33}.radio-row.sel{border-color:var(--green);background:var(--green-dim2)}.radio-dot{width:16px;height:16px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;position:relative}.radio-row.sel .radio-dot{border-color:var(--green)}.radio-row.sel .radio-dot:after{content:"";width:8px;height:8px;background:var(--green);border-radius:50%;position:absolute}.radio-text{font-size:13px;color:var(--text)}.export-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}.export-card{border:1.5px solid var(--border);border-radius:var(--radius);padding:16px;cursor:pointer;transition:all .2s;text-align:center}.export-card:hover{border-color:#3d3d3c40}.export-card.sel{border-color:var(--green);background:var(--green-dim2)}.export-icon{font-size:28px;margin-bottom:8px}.export-name{font-size:13px;font-weight:600;color:var(--text)}.export-desc{font-size:11px;color:var(--text2);margin-top:2px}.schedule-row{display:flex;align-items:center;gap:12px;padding:14px;background:var(--bg2);border-radius:8px;border:1.5px solid var(--border);margin-bottom:14px}.toggle-sw{width:36px;height:20px;background:var(--bg3);border:1.5px solid var(--border);border-radius:10px;position:relative;cursor:pointer;transition:all .2s;flex-shrink:0}.toggle-sw.on{background:var(--green);border-color:var(--green)}.toggle-sw:after{content:"";position:absolute;top:2px;left:2px;width:12px;height:12px;background:#fff;border-radius:50%;transition:left .2s;box-shadow:0 1px 3px #0003}.toggle-sw.on:after{left:18px}.toggle-label{font-size:13px;color:var(--text);font-weight:500}.constructor-nav{display:flex;align-items:center;justify-content:space-between;padding:16px 22px;border-top:1px solid var(--border2);margin-top:4px}.saved-list{display:flex;flex-direction:column;gap:10px}.saved-item{display:flex;align-items:center;gap:14px;padding:16px 18px;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all .15s}.saved-item:hover{border-color:var(--green);box-shadow:0 3px 14px #52ae321a}.saved-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.saved-info{flex:1;min-width:0}.saved-name{font-size:13px;font-weight:600;color:var(--text)}.saved-meta{font-size:11px;color:var(--text3);margin-top:3px}.saved-actions{display:flex;gap:6px;flex-shrink:0}.preview-meta{display:flex;gap:14px;margin-bottom:20px}.pm-card{flex:1;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);padding:16px}.pm-label{font-size:11px;color:var(--text3);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:5px}.pm-val{font-size:24px;font-weight:700;color:var(--text)}.pm-sub{font-size:11px;color:var(--text3);margin-top:3px}.data-table-wrap{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.data-table{width:100%;border-collapse:collapse;font-size:12.5px}.data-table thead th{padding:11px 14px;background:var(--bg2);font-weight:600;color:var(--text2);text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.04em;border-bottom:1.5px solid var(--border);white-space:nowrap}.data-table td{padding:10px 14px;border-bottom:1px solid var(--border2);color:var(--text)}.data-table tr:last-child td{border-bottom:none}.data-table tr.group-header td{background:var(--bg2);font-weight:600;font-size:12px;color:var(--text2);padding:7px 14px}.data-table tr.total-row td{background:var(--text);color:#fff;font-weight:600;padding:11px 14px}.data-table tbody tr:not(.group-header):not(.total-row):hover td{background:var(--bg2)}.num{text-align:right;font-family:monospace;font-size:12px}.sep{border:none;border-top:1px solid var(--border2);margin:18px 0}.tip{font-size:12px;color:var(--text3);margin-top:10px;display:flex;align-items:flex-start;gap:5px;line-height:1.5}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.section-title{font-size:13px;color:var(--text2)}.success-banner{background:var(--green-dim);border:1.5px solid rgba(82,174,50,.25);border-radius:var(--radius);padding:16px 18px;margin-bottom:20px;display:flex;align-items:center;gap:12px}.toast{position:fixed;bottom:24px;right:24px;background:var(--text);color:#fff;padding:12px 18px;border-radius:var(--radius);font-size:13px;font-weight:500;box-shadow:0 8px 32px #3d3d3c40;display:none;z-index:9999;align-items:center;gap:10px}.toast.show{display:flex;animation:slideIn .22s ease}@keyframes slideIn{0%{transform:translateY(14px);opacity:0}to{transform:translateY(0);opacity:1}}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.auth-block{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:22px 24px;margin-bottom:20px}.auth-block-header{display:flex;align-items:center;gap:10px;margin-bottom:16px}.auth-block-icon{width:34px;height:34px;border-radius:9px;background:var(--green-dim);display:flex;align-items:center;justify-content:center;flex-shrink:0}.auth-block-title{font-size:14px;font-weight:600;color:var(--text)}.auth-block-sub{font-size:12px;color:var(--text3);margin-top:2px}.auth-form{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:10px;align-items:end}.auth-error{font-size:12px;color:#d94040;margin-top:8px;display:none}.auth-error.show{display:block}.auth-success-bar{display:none;align-items:center;gap:14px;padding:12px 16px;background:var(--green-dim);border:1.5px solid rgba(82,174,50,.25);border-radius:9px}.auth-success-bar.show{display:flex}.auth-client-badge{font-size:12px;font-weight:600;color:var(--green)}.auth-client-name{font-size:13px;font-weight:500;color:var(--text)}.auth-client-code{font-size:11px;color:var(--text3);font-family:monospace}.auth-logout{margin-left:auto;font-size:12px;color:var(--text3);cursor:pointer;text-decoration:underline;background:none;border:none;font-family:Rubik,sans-serif}.auth-logout:hover{color:var(--text)}.lockable{position:relative}.lock-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;border-radius:var(--radius-lg);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);background:#f7f8fa8c;pointer-events:all}.lock-overlay svg{opacity:.45}.lock-overlay-text{font-size:13px;font-weight:500;color:var(--text2)}.lockable.unlocked .lock-overlay{display:none}.lockable.unlocked>*:not(.lock-overlay){pointer-events:auto}.lockable:not(.unlocked)>*:not(.lock-overlay){pointer-events:none}.sync-progress-bar{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);padding:12px 16px;margin-bottom:16px;display:flex;align-items:center;gap:12px}.sync-progress-track{flex:1;height:6px;background:var(--bg3);border-radius:3px;overflow:hidden}.sync-progress-fill{height:100%;background:var(--green);border-radius:3px;transition:width .3s ease}.sync-progress-text{font-size:12px;color:var(--text2);white-space:nowrap}
