.sidebar{width:80px;height:100vh;background:var(--oc-rail);display:flex;flex-direction:column;align-items:center;padding:16px 0;gap:12px;position:fixed;left:0;top:0;bottom:0;z-index:3000}.ocular-badge{width:48px;height:48px;display:flex;align-items:center;justify-content:center;margin-bottom:8px}.icon-button{width:48px;height:48px;background:transparent;border:none;color:#fff9;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s;position:relative}.icon-button svg{stroke:currentColor;stroke-width:.6;stroke-linejoin:round;stroke-linecap:round;paint-order:stroke fill}.icon-button:hover{background:#ffffff1a;color:#ffffffe6}.icon-button[data-active=true]{background:#efba2b33;color:var(--oc-accent)}.tooltip{position:absolute;left:100%;margin-left:8px;background:#000000e6;color:#fff;padding:6px 12px;border-radius:6px;font-size:12px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .2s;z-index:1000}.icon-button:hover .tooltip{opacity:1}.sidebar-divider{width:48px;height:1px;margin:8px 0 4px;background:#ffffff26}.sidebar-bottom{margin-top:auto;display:flex;flex-direction:column;align-items:center;gap:12px}.color-swatch-input{display:flex;align-items:center;gap:10px}.color-preview-bar{width:200px;height:16px;border-radius:6px;border:1px solid #E5E7EB;box-shadow:inset 0 0 0 1px #fff9}.color-picker-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;border:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap}.color-picker-trigger{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:24px;aspect-ratio:1 / 1;height:auto;min-width:24px;min-height:24px;padding:0;border-radius:9999px;border:none;box-shadow:none;cursor:pointer;display:inline-block;vertical-align:middle}.color-picker-trigger.is-bar{width:24px;aspect-ratio:1 / 1}.color-picker-trigger:focus-visible{outline:2px solid var(--oc-accent, #EFBA2B);outline-offset:2px}.color-text{width:140px;padding:6px 8px;border:1px solid #D1D5DB;border-radius:6px;font:inherit;outline:none}.color-text:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.color-remove{background:none;border:none;color:#ef4444;font-size:18px;cursor:pointer;padding:0 6px;line-height:1}.color-swatch-input.invalid .color-text{border-color:#ef4444}.font-select{display:flex;flex-direction:column}.font-select label{font-size:12px;color:#6b7280;margin-bottom:4px}.font-select select{padding:8px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;background:#fff;cursor:pointer;transition:all .2s}.font-select select:focus{outline:none;border-color:var(--oc-accent);box-shadow:0 0 0 3px #efba2b1a}.file-drop{border:2px dashed #d1d5db;border-radius:8px;padding:24px;text-align:center;cursor:pointer;transition:all .2s;background:#f9fafb}.file-drop:hover{border-color:#9ca3af;background:#f3f4f6}.file-drop:focus-visible{outline:2px solid var(--oc-accent);outline-offset:2px}.file-drop.dragging{border-color:var(--oc-accent);background:#efba2b0d}.file-drop svg{margin:0 auto 12px;color:#9ca3af}.file-drop p{color:#6b7280;font-size:14px;margin:0}.file-drop-hint{margin-top:4px!important;font-size:12px!important;color:#9ca3af!important}.ui-button{position:relative;display:inline-flex;align-items:center;justify-content:center;font-family:inherit;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;outline:none}.ui-button--sm{padding:6px 12px;font-size:12px}.ui-button--md{padding:10px 20px;font-size:14px}.ui-button--lg{padding:14px 28px;font-size:16px}.ui-button--primary{background-color:var(--oc-accent);color:var(--oc-panel)}.ui-button--primary:hover:not(:disabled){background-color:var(--brand-primary, var(--oc-accent));transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.ui-button--secondary{background-color:var(--oc-panel);color:var(--oc-ink);border:1px solid var(--oc-panel-muted)}.ui-button--secondary:hover:not(:disabled){background-color:var(--oc-panel-muted)}.ui-button--ghost{background-color:transparent;color:var(--oc-ink)}.ui-button--ghost:hover:not(:disabled){background-color:#ffffff1a}.ui-button:disabled{opacity:.5;cursor:not-allowed}.ui-button--full-width{width:100%}.ui-button--loading{color:transparent}.ui-button__spinner{position:absolute;display:flex;align-items:center;justify-content:center}.ui-button__spinner-icon{width:20px;height:20px;animation:spin 1s linear infinite}.ui-button__spinner-circle{stroke-dasharray:62.83;stroke-dashoffset:47.12;stroke-linecap:round}.ui-button__content--hidden{visibility:hidden}@keyframes spin{to{transform:rotate(360deg)}}.ui-button:focus-visible{outline:2px solid var(--oc-accent);outline-offset:2px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:var(--oc-radius);width:90%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e5e7eb}.modal-header h2{font-size:20px;font-weight:600;color:#111827}.modal-close{background:none;border:none;color:#6b7280;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s}.modal-close:hover{background:#f3f4f6;color:#111827}.modal-body{flex:1;overflow-y:auto;padding:24px}.form-group{margin-bottom:24px}.form-group label{display:block;margin-bottom:8px;font-size:14px;font-weight:500;color:#374151}.form-group input[type=text]{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:all .2s}.form-group input[type=text]:focus{outline:none;border-color:var(--oc-accent);box-shadow:0 0 0 3px #efba2b1a}.form-group input.error{border-color:#ef4444}.error-message{color:#ef4444;font-size:12px;margin-top:4px;display:block}.color-list{display:flex;flex-wrap:wrap;gap:12px}.add-color-button{padding:8px 16px;background:#f3f4f6;border:1px dashed #d1d5db;border-radius:8px;color:#6b7280;cursor:pointer;font-size:14px;transition:all .2s}.add-color-button:hover{background:#e5e7eb;border-color:#9ca3af;color:#374151}.font-inputs{display:flex;gap:16px}.font-inputs>*{flex:1}.icon-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:12px;margin-top:16px}.icon-preview{position:relative;width:80px;height:80px;border:1px solid #e5e7eb;border-radius:8px;padding:8px;display:flex;align-items:center;justify-content:center;background:#f9fafb}.icon-preview svg,.icon-preview img{max-width:100%;max-height:100%;object-fit:contain}.icon-remove{position:absolute;top:-8px;right:-8px;width:24px;height:24px;background:#ef4444;color:#fff;border:none;border-radius:50%;cursor:pointer;font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .2s}.icon-remove:hover{background:#dc2626;transform:scale(1.1)}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:24px;border-top:1px solid #e5e7eb}.btn-primary,.btn-secondary{padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:none}.btn-primary{background:var(--oc-accent);color:var(--oc-panel)}.btn-primary:hover{background:var(--brand-accent-alt, #f5c541);transform:translateY(-1px)}.btn-secondary{background:#f3f4f6;color:#374151}.btn-secondary:hover{background:#e5e7eb}.brand-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.brand-modal{background:#fff;color:#111827;border-radius:var(--oc-radius);width:min(1100px,92vw);max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;overflow:hidden}.brand-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #E5E7EB}.brand-modal-header h2{margin:0;font-size:20px;font-weight:600}.brand-modal-close{background:none;border:none;color:#6b7280;cursor:pointer;padding:4px 8px;border-radius:6px}.brand-modal-close:hover{background:#f3f4f6;color:#111827}.brand-modal-form{flex:1;overflow:auto;padding:24px}.brand-modal-actions{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #E5E7EB}.palette-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.palette-item{display:flex;align-items:center;gap:8px}.add-color-btn,.remove-color-btn{margin-left:8px;background:#f3f4f6;border:1px solid #D1D5DB;border-radius:6px;color:#374151;cursor:pointer}.add-color-btn{padding:6px 10px}.remove-color-btn{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;padding:0;font-size:18px;line-height:1}.add-color-btn:hover,.remove-color-btn:hover{background:#e5e7eb}.logo-preview{margin-top:8px;max-width:180px;max-height:60px;object-fit:contain}.brand-settings-view{display:flex;height:100%;flex:1 1 auto;min-width:0;background:var(--oc-bg);color:#111827;position:relative;z-index:1}.brand-settings-view.two-column{flex-direction:row}.brand-settings-left{width:520px;padding:48px 40px;display:flex;flex-direction:column;background:var(--oc-panel);color:var(--oc-ink);border-right:1px solid rgba(255,255,255,.08)}.brand-settings-right{flex:1;padding:48px 40px;border-left:1px solid #E5E7EB;overflow:auto;background:transparent}.brand-settings-header{margin-bottom:32px}.brand-settings-header h2{font-size:18px;font-weight:600;color:var(--oc-ink);line-height:1.4}.brand-list{flex:1;display:flex;flex-direction:column;gap:12px;margin-bottom:32px;overflow-y:auto}.brand-card{display:flex;align-items:center;gap:8px;padding:12px 14px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:10px;color:var(--oc-ink);transition:transform .15s ease,background .2s ease,border-color .2s ease;text-align:left}.brand-card{cursor:default}.brand-card:hover{transform:translateY(-1px);background:#ffffff1a}.brand-card.active{border-color:var(--oc-accent);box-shadow:0 0 0 2px #efba2b40 inset;background:#efba2b26}.brand-swatch{width:20px;height:20px;border-radius:4px;box-shadow:inset 0 0 0 1px #00000026}.brand-name{flex:1;font-size:14px;color:var(--oc-ink)}.brand-card-main{flex:1;display:flex;align-items:center;gap:12px;padding:0;background:none;border:none;color:inherit;cursor:pointer;text-align:left}.brand-card-main:focus-visible{outline:2px solid var(--oc-accent);outline-offset:2px}.brand-delete{padding:6px;background:transparent;border:none;color:#fff9;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:16px;line-height:1;transition:all .2s}.brand-delete:hover{background:#ffffff1f;color:var(--oc-ink)}.brand-delete:focus-visible{outline:2px solid var(--oc-accent);outline-offset:2px}.brand-list-item{display:flex;align-items:center;justify-content:space-between;height:48px;padding:0 16px;background:#ffffff0d;border-radius:8px;transition:background .2s}.brand-list-item:hover{background:#ffffff14}.brand-checkbox-wrapper{display:flex;align-items:center;gap:12px;cursor:pointer;flex:1}.brand-checkbox-wrapper input{position:absolute;opacity:0;pointer-events:none}.brand-checkbox{width:20px;height:20px;border:2px solid rgba(255,255,255,.35);border-radius:4px;background:transparent;display:flex;align-items:center;justify-content:center;transition:all .2s}.brand-checkbox-wrapper input:checked~.brand-checkbox{background:var(--oc-accent);border-color:var(--oc-accent);box-shadow:0 0 12px #efba2b59}.brand-checkbox-wrapper input:disabled~.brand-checkbox{opacity:.45;cursor:not-allowed}.brand-checkbox-check{display:none;color:var(--oc-panel);width:12px;height:12px}.brand-checkbox-wrapper input:checked~.brand-checkbox .brand-checkbox-check{display:block}.brand-name{font-size:14px;color:var(--oc-ink);-webkit-user-select:none;user-select:none}.add-brand-button{width:100%;height:48px;background:var(--oc-accent);color:var(--oc-panel);border:none;border-radius:var(--oc-radius);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:auto}.add-brand-button:hover{background:var(--brand-accent-alt, #f5c541);transform:translateY(-1px)}.brand-panel-header{color:#111827;margin-bottom:32px}.brand-panel-header h2{margin:0;font-size:18px;font-weight:600}.brand-settings-right .form-group label{color:#111827!important}.percent-donut-container{display:flex;align-items:center;gap:60px;padding:40px}.donut-chart{position:relative;flex-shrink:0}.donut-chart svg{display:block}.donut-progress{transition:all .5s cubic-bezier(.4,0,.2,1)}.donut-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center}.donut-content{flex:1;max-width:400px}.donut-percentage{font-size:72px;font-weight:700;line-height:1;margin-bottom:20px;transition:color .3s}.donut-text{font-size:16px;line-height:1.6;transition:color .3s}.donut-card.export-mode{background:transparent!important}.download-asset-container{position:relative;display:inline-block}.download-asset-button{display:flex;align-items:center;gap:8px;padding:8px 16px;background-color:var(--oc-accent, #EFBA2B);color:var(--oc-panel, #44403E);border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:14px;transition:opacity .2s ease}.download-asset-button:hover:not(:disabled){opacity:.9}.download-asset-button:disabled{opacity:.6;cursor:wait}.download-menu{position:absolute;bottom:calc(100% + 8px);right:0;min-width:220px;background-color:var(--oc-panel, #44403E);border:1px solid var(--oc-panel-muted, #605E5E);border-radius:8px;box-shadow:0 4px 12px #00000026;overflow:hidden;z-index:1000;animation:slideUp .2s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.download-menu-header{padding:8px 12px;font-size:12px;color:var(--oc-ink-muted, #CFCFCF);border-bottom:1px solid var(--oc-panel-muted, #605E5E);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.download-menu-item{display:flex;justify-content:space-between;align-items:center;width:100%;padding:10px 12px;background:none;border:none;color:var(--oc-ink, #FFFFFF);cursor:pointer;font-size:14px;text-align:left;transition:background-color .15s ease}.download-menu-item:hover{background-color:var(--oc-panel-muted, #605E5E)}.download-menu-item:focus{outline:2px solid var(--oc-accent, #EFBA2B);outline-offset:-2px}.download-menu-hint{font-size:12px;color:var(--oc-ink-muted, #CFCFCF);margin-left:8px}.download-menu-divider{height:1px;background-color:var(--oc-panel-muted, #605E5E);margin:4px 0}@media (max-width: 768px){.download-menu{min-width:200px;right:auto;left:50%;transform:translate(-50%)}}.percent-donut-toolbar{position:absolute;bottom:0;left:0;right:0;height:60px;background:#e5e7eb;border-top:1px solid #D1D5DB;display:flex;align-items:center;padding:0 20px;gap:12px}.toolbar-button:active:not(:disabled){transform:translateY(0)}.icon-picker-container{position:relative}.icon-picker-popover{position:absolute;bottom:100%;left:0;margin-bottom:8px;background:#fff;border:1px solid #D1D5DB;border-radius:8px;padding:12px;box-shadow:0 10px 25px #0000001a;z-index:100}.icon-picker-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.icon-picker-item{width:40px;height:40px;background:#f9fafb;border:1px solid #E5E7EB;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;color:#374151}.icon-picker-item:hover{background:var(--oc-accent);border-color:var(--oc-accent);color:#fff}.icon-picker-item:focus-visible{outline:2px solid var(--oc-accent);outline-offset:2px}.card{background:#fff;border-radius:var(--oc-radius);padding:24px;box-shadow:0 2px 8px #0000001a}.card.export-mode{background:transparent!important;box-shadow:none!important}.charts-bar-view{display:flex;height:100%;width:100%}.charts-bar-controls{min-width:520px;background:var(--oc-panel);color:var(--oc-ink);padding:48px 40px;display:flex;flex-direction:column;gap:32px}.control-group{display:flex;flex-direction:column;gap:8px}.control-group label{font-size:14px;font-weight:500;color:var(--oc-ink)}.control-group input[type=number],.control-group textarea{padding:10px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--oc-ink);font-size:14px;transition:all .2s}.control-group input[type=number]:focus,.control-group textarea:focus{outline:none;border-color:var(--oc-accent);background:#ffffff14}.control-group input.error,.control-group textarea.error{border-color:#ef4444}.control-group textarea{resize:vertical;min-height:80px;font-family:inherit}.control-group input.error+.helper-text,.control-group textarea.error+.helper-text{color:#ef4444}.swatch{width:48px;height:48px;border-radius:8px;border:2px solid transparent;cursor:pointer;transition:all .2s;position:relative}.charts-bar-canvas{flex:1;background:var(--oc-bg);display:flex;flex-direction:column;padding:40px;position:relative}.donut-card{flex:0 1 880px;width:100%;max-width:880px;display:flex;align-items:center;justify-content:center;border-radius:var(--oc-radius);transition:background .3s}.donut-card.bg-white{background:#fff}.donut-card.bg-dark{background:var(--oc-panel)}.donut-card.bg-transparent{background-image:repeating-conic-gradient(#f0f0f0,#f0f0f0 25%,#fff 0%,#fff 50%);background-size:20px 20px}.control-group select{padding:10px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--oc-ink);font-size:14px;transition:all .2s;cursor:pointer}.control-group select:focus{outline:none;border-color:var(--oc-accent);background:#ffffff14}.bars-toolbar{position:absolute;bottom:0;left:0;right:0;height:60px;background:#e5e7eb;border-top:1px solid #D1D5DB;display:flex;align-items:center;padding:0 20px;gap:12px}.toolbar-button:active{transform:translateY(0)}.charts-vertical-bars-view{display:flex;height:100%;width:100%}.charts-bars-controls{min-width:520px;background:var(--oc-panel);color:var(--oc-ink);padding:48px 40px;display:flex;flex-direction:column;gap:32px;overflow-y:auto}.control-section h3{font-size:14px;font-weight:500;color:var(--oc-ink);margin-bottom:8px}.bars-inputs{display:flex;flex-direction:column;gap:12px}.bar-input-row{display:flex;gap:12px}.remove-bar{width:32px;height:32px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:var(--oc-ink);cursor:pointer;transition:all .2s;align-self:center}.remove-bar:hover:not(:disabled){background:#ef4444;border-color:#ef4444}.remove-bar:disabled{opacity:.5;cursor:not-allowed}.bars-actions{margin-top:8px;display:flex;align-items:center;gap:12px}.add-bar{padding:8px 12px;background:#ffffff0d;border:1px dashed rgba(255,255,255,.3);border-radius:8px;color:var(--oc-ink);cursor:pointer;transition:all .2s}.add-bar:hover:not(:disabled){background:#ffffff1a;border-color:var(--oc-accent)}.add-bar:disabled{opacity:.5;cursor:not-allowed}.input-group{flex:1}.input-group input{width:100%;padding:10px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--oc-ink);font-size:14px;transition:all .2s}.input-group input:focus{outline:none;border-color:var(--oc-accent);background:#ffffff14}.input-group input.error{border-color:#ef4444}.charts-bars-canvas{flex:1;background:var(--oc-bg);display:flex;flex-direction:column;position:relative;padding:40px}.bars-card{width:100%;max-width:900px;padding:40px;border-radius:var(--oc-radius);transition:background .3s;display:flex;align-items:center;justify-content:center}.bars-card.bg-white{background:#fff}.bars-card.bg-dark{background:var(--oc-panel)}.bars-card.bg-transparent{background-image:repeating-conic-gradient(#f0f0f0,#f0f0f0 25%,#fff 0%,#fff 50%);background-size:20px 20px}.bars-content{display:flex;width:100%;max-width:880px;gap:32px;align-items:center;justify-content:center}.chart-wrapper{flex:0 0 56%;max-width:56%;display:flex;justify-content:center;align-items:center}.text-block{flex:1;display:flex;align-items:center;font-size:16px;line-height:1.6;max-width:420px}.bars-card.export-mode{background:transparent!important}@media (max-width: 1100px){.bars-content{flex-direction:column;gap:24px}.chart-wrapper{flex:none;max-width:none}.text-block{max-width:none;justify-content:flex-start}}.bars-card-inner{width:100%;height:100%;display:flex;justify-content:center;align-items:center}.charts-line-view{display:flex;height:100%;width:100%}.charts-line-controls{width:520px;background:var(--oc-panel);color:var(--oc-ink);padding:48px 40px;display:flex;flex-direction:column;gap:24px;overflow-y:auto}.control-section{display:flex;flex-direction:column;gap:12px}.control-section h3,.control-section label{font-size:14px;font-weight:500;color:var(--oc-ink)}.series-group{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.series-header{display:flex;justify-content:space-between;align-items:center}.series-label{font-size:13px;color:var(--oc-ink-muted)}.series-inputs{display:flex;gap:12px}.series-inputs input,.x-labels-inputs input{flex:1;padding:10px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--oc-ink);font-size:14px;transition:all .2s}.series-inputs input:focus,.x-labels-inputs input:focus{outline:none;border-color:var(--oc-accent);background:#ffffff14}.series-inputs input.error{border-color:#ef4444}.remove-series{width:24px;height:24px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:var(--oc-ink-muted);font-size:18px;cursor:pointer;transition:all .2s}.remove-series:hover{background:#ef4444;border-color:#ef4444;color:#fff}.add-series-button{padding:10px 16px;background:#ffffff0d;border:1px dashed rgba(255,255,255,.3);border-radius:8px;color:var(--oc-ink-muted);font-size:14px;cursor:pointer;transition:all .2s}.add-series-button:hover{background:#ffffff1a;border-color:var(--oc-accent);color:var(--oc-ink)}.toggle-row{display:flex;justify-content:space-between;align-items:center}.toggle-button{padding:6px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:var(--oc-ink-muted);font-size:13px;cursor:pointer;transition:all .2s}.toggle-button.active{background:var(--oc-accent);border-color:var(--oc-accent);color:var(--oc-panel)}.legend-inputs{display:flex;flex-direction:column;gap:8px}.legend-inputs input{padding:8px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--oc-ink);font-size:13px}.x-labels-inputs{display:flex;gap:12px}.control-section textarea{padding:10px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--oc-ink);font-size:14px;font-family:inherit;resize:vertical;min-height:80px;transition:all .2s}.control-section textarea:focus{outline:none;border-color:var(--oc-accent);background:#ffffff14}.helper-text{font-size:12px;color:var(--oc-ink-muted)}.charts-line-canvas{flex:1;background:var(--oc-bg);display:flex;flex-direction:column;position:relative;padding:40px}.chart-container{flex:1;display:flex;align-items:center;justify-content:center}.lines-card{width:100%;max-width:1000px;padding:40px;border-radius:var(--oc-radius);transition:background .3s;display:flex;justify-content:center;align-items:center}.lines-card.bg-white{background:#fff}.lines-card.bg-dark{background:var(--oc-panel)}.lines-card.bg-transparent{background-image:repeating-conic-gradient(#f0f0f0,#f0f0f0 25%,#fff 0%,#fff 50%);background-size:20px 20px}.lines-content{display:grid;width:100%;max-width:900px;grid-template-columns:minmax(340px,1fr) 320px;column-gap:36px;align-items:center;justify-content:center}.lines-side{display:flex;flex-direction:column;justify-content:space-between;width:100%;max-width:320px;min-width:0}.text-block{flex:0 0 auto;width:100%;max-width:320px;min-width:0;font-size:15px;line-height:1.6;word-break:break-word;overflow-wrap:anywhere}.legend-inline{display:flex;flex-direction:column;gap:8px;margin-top:8px}.legend-item{display:flex;align-items:center;gap:10px;color:inherit}.legend-swatch{width:14px;height:14px;border-radius:2px;display:inline-block}.legend-label{font-size:13px}.lines-toolbar{position:absolute;bottom:0;left:0;right:0;height:60px;background:#e5e7eb;border-top:1px solid #D1D5DB;display:flex;align-items:center;padding:0 20px;gap:12px}.series-inputs,.x-labels-inputs{display:grid;grid-template-columns:repeat(var(--x-count, 3),minmax(0,1fr));gap:12px}.series-header .remove-series{margin-left:8px}.series-header{justify-content:flex-start;gap:8px}.bars-hint{color:var(--oc-ink-muted);font-size:12px}.lines-card.export-mode{background:transparent!important}.image-overlay-container{position:relative;width:100%;max-width:900px;overflow:hidden;border-radius:0;display:flex;align-items:center;justify-content:center;background:#fff}.image-overlay-container.bg-white{background:#fff}.image-overlay-container.bg-dark{background:var(--oc-panel)}.image-overlay-container.bg-transparent{background-image:repeating-conic-gradient(#f0f0f0,#f0f0f0 25%,#fff 0%,#fff 50%);background-size:20px 20px}.overlay-image{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.color-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.text-content{position:relative;z-index:2;padding:60px;width:100%;height:100%;display:flex;flex-direction:column;justify-content:flex-end;gap:12px}.overlay-headline{font-size:72px;font-weight:700;line-height:1;margin:0}.overlay-body{font-size:20px;line-height:1.4;margin:0;max-width:600px}.no-image-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:16px;padding:60px;color:#9ca3af;z-index:3}.image-overlay-container.export-mode{background:transparent!important}.image-library-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.image-library{background:#fff;border-radius:var(--oc-radius);width:90%;max-width:800px;max-height:600px;position:relative;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.image-library-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e5e7eb}.image-library-header h3{margin:0;font-size:18px;font-weight:600;color:#111827}.close-button{background:none;border:none;color:#6b7280;cursor:pointer;padding:6px;border-radius:6px;line-height:1;font-size:20px;transition:all .2s}.close-button:hover{background:#f3f4f6;color:#111827}.image-library-upload{padding:20px}.image-library-divider{padding:0 20px;color:#6b7280;font-size:12px}.image-library-grid{padding:20px;display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;overflow-y:auto}.image-library-item{display:flex;flex-direction:column;gap:8px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:8px;cursor:pointer;transition:all .2s;color:#374151}.image-library-item:hover{border-color:var(--oc-accent);box-shadow:0 4px 12px #00000014}.image-library-item img{width:100%;height:100px;object-fit:cover;border-radius:6px}.image-library-item-name{font-size:12px;color:#6b7280;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.library-gallery{display:flex;align-items:center;gap:16px}.gallery-nav{width:40px;height:40px;background:#f3f4f6;border:1px solid #D1D5DB;border-radius:50%;font-size:24px;cursor:pointer;color:#374151;transition:all .2s}.gallery-nav:hover:not(:disabled){background:#e5e7eb}.gallery-nav:disabled{opacity:.3;cursor:not-allowed}.gallery-images{flex:1;display:flex;gap:16px;justify-content:center}.gallery-image{width:150px;height:150px;border:2px solid transparent;border-radius:8px;overflow:hidden;cursor:pointer;transition:all .2s}.gallery-image:hover{border-color:var(--oc-accent);transform:scale(1.05)}.gallery-image img{width:100%;height:100%;object-fit:cover}.image-toolbar{position:absolute;bottom:0;left:0;right:0;height:60px;background:#e5e7eb;border-top:1px solid #D1D5DB;display:flex;align-items:center;justify-content:flex-start;padding:0 20px;gap:12px;z-index:20}.toolbar-group{display:flex;align-items:center;gap:12px}.toolbar-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.opacity-controls{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #D1D5DB;border-radius:8px;padding:4px}.opacity-button{width:28px;height:28px;background:transparent;border:none;cursor:pointer;font-size:18px;color:#374151;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.opacity-button:hover{background:#f3f4f6}.opacity-value{font-size:12px;color:#374151;min-width:35px;text-align:center}.aspect-menu-container{position:relative}.aspect-menu{position:absolute;bottom:100%;left:0;margin-bottom:8px;background:#fff;border:1px solid #D1D5DB;border-radius:8px;box-shadow:0 10px 25px #0000001a;overflow:hidden;min-width:100px;z-index:200}.aspect-option{display:block;width:100%;padding:8px 16px;background:none;border:none;text-align:left;font-size:13px;color:#000;cursor:pointer;transition:background .2s}.aspect-menu .aspect-option{color:#000}.aspect-option:hover{background:#f3f4f6}.aspect-option.active{background:var(--oc-accent);color:#fff}.aspect-button:before{content:"";display:block;width:20px;height:20px;background-repeat:no-repeat;background-position:center;background-size:contain;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'><rect x='3' y='3' width='18' height='18' rx='2'/><rect x='7' y='7' width='10' height='10' rx='1' stroke-dasharray='2 2'/></svg>")}.cropper-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:2000}.cropper-container{width:90%;max-width:1200px;height:90%;display:flex;flex-direction:column;gap:20px}.crop-area{flex:1;position:relative;background:#000}.cropper-controls{background:#fff;padding:20px;border-radius:8px;display:flex;justify-content:space-between;align-items:center}.zoom-control{display:flex;align-items:center;gap:12px}.zoom-control label{font-size:14px;color:#374151}.zoom-control input[type=range]{width:200px}.cropper-actions{display:flex;gap:12px}.btn-cancel,.btn-confirm{padding:10px 24px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-cancel{background:#f3f4f6;color:#374151}.btn-cancel:hover{background:#e5e7eb}.btn-confirm{background:var(--oc-accent);color:#fff}.btn-confirm:hover{background:#f5c541;transform:translateY(-1px)}.images-view{display:flex;height:100%;width:100%}.images-controls{min-width:520px;background:var(--oc-panel);color:var(--oc-ink);padding:48px 40px;display:flex;flex-direction:column;gap:32px}.control-section input[type=text],.control-section textarea{width:100%;padding:10px 12px;border:1px solid rgba(255,255,255,.2);border-radius:8px;background:#ffffff0d;color:var(--oc-ink);font-size:14px;transition:border-color .2s ease,background .2s ease}.size-buttons{display:flex;gap:12px}.size-button{padding:8px 14px;background:#ffffff0d;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:var(--oc-ink);font-size:14px;cursor:pointer;transition:all .2s}.size-button:hover{background:#ffffff1a;border-color:var(--oc-accent)}.background-swatches{display:flex;gap:12px}.swatch{width:48px;height:48px;border-radius:8px;border:2px solid transparent;cursor:pointer;transition:all .2s}.swatch:hover{transform:scale(1.05)}.swatch.active{border-color:var(--oc-accent);box-shadow:0 0 0 2px #efba2b33}.swatch-white{background:#fff;border:2px solid rgba(255,255,255,.3)}.swatch-dark{background:var(--oc-panel);border:2px solid rgba(255,255,255,.3)}.swatch-transparent{background-image:repeating-conic-gradient(gray,gray 25%,silver 0%,silver 50%);background-size:16px 16px;border:2px solid rgba(255,255,255,.3)}.images-canvas{flex:1;background:var(--oc-bg);display:flex;flex-direction:column;position:relative;padding:40px}.split-image-container{position:relative;width:100%;max-width:1200px;overflow:hidden;border-radius:0;background:#fff}.split-image-container.bg-white{background:#fff}.split-image-container.bg-dark{background:var(--oc-panel)}.split-image-container.bg-transparent{background-image:repeating-conic-gradient(#f0f0f0,#f0f0f0 25%,#fff 0%,#fff 50%);background-size:20px 20px}.split-layout{display:flex;width:100%;height:100%}.split-image-side{flex:1;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#f3f4f6}.split-image-side img{width:100%;height:100%;object-fit:cover}.split-panel-side{flex:1;display:flex;align-items:center;justify-content:center;padding:60px}.panel-content{max-width:400px;width:100%}.panel-headline{font-size:64px;font-weight:700;line-height:1;margin:0 0 24px}.panel-body{font-size:18px;line-height:1.6;margin:0 0 32px}.panel-cta{padding:14px 32px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s}.panel-cta:hover{transform:translateY(-2px)}.no-image-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:#9ca3af}.no-image-placeholder p{font-size:14px;margin:0}@media (max-width: 768px){.split-layout{flex-direction:column}.split-panel-side{padding:40px}.panel-headline{font-size:48px}}.split-image-container.export-mode{background:transparent!important}.split-image-toolbar{position:absolute;bottom:0;left:0;right:0;height:60px;background:#e5e7eb;border-top:1px solid #D1D5DB;display:flex;align-items:center;justify-content:flex-start;padding:0 20px}.toolbar-left,.toolbar-right{display:flex;align-items:center;gap:12px}.toolbar-button{width:40px;height:40px;background:#fff;border:1px solid #D1D5DB;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;color:#374151}.toolbar-button:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af;transform:translateY(-1px)}.toolbar-button:disabled{opacity:.4;cursor:not-allowed}.toolbar-button:focus-visible{outline:2px solid var(--oc-accent);outline-offset:2px}.split-image-view{display:flex;height:100%;width:100%}.split-image-controls{min-width:520px;background:var(--oc-panel);color:var(--oc-ink);padding:48px 40px;display:flex;flex-direction:column;gap:32px}.control-section{display:flex;flex-direction:column;gap:8px}.control-section label{font-size:14px;font-weight:500;color:var(--oc-ink)}.control-section input[type=text],.control-section textarea{padding:10px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--oc-ink);font-size:14px;transition:all .2s}.control-section input[type=text]:focus,.control-section textarea:focus{outline:none;border-color:var(--oc-accent);background:#ffffff14}.control-section textarea{font-family:inherit;resize:vertical;min-height:80px}.control-section textarea.error{border-color:#ef4444}.helper-text{font-size:12px;color:var(--oc-ink-muted);min-height:16px}.control-section .error+.helper-text{color:#ef4444}.split-image-canvas{flex:1;background:var(--oc-bg);display:flex;flex-direction:column;position:relative;padding:40px}.export-container{flex:1;display:flex;align-items:center;justify-content:center}.control-section select{padding:10px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--oc-ink);font-size:14px;transition:all .2s;cursor:pointer}.control-section select:focus{outline:none;border-color:var(--oc-accent);background:#ffffff14}.illustration-card{width:100%;display:flex;align-items:center;padding:24px;box-sizing:border-box;justify-content:center;gap:24px;transition:background-color .3s ease}.illustration-card.bg-white{background-color:#fff}.illustration-card.bg-dark{background-color:#343434}.illustration-card.bg-transparent{background-image:repeating-conic-gradient(#f0f0f0,#f0f0f0 25%,#fff 0%,#fff 50%);background-size:20px 20px}.icon-block{display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;transition:all .2s ease}.icon-scale{display:flex;align-items:center;justify-content:center;transform-origin:center}.icon-block.has-ring{border:2px solid currentColor;border-radius:50%}.icon-block-content{display:flex;align-items:center;justify-content:center}.icon-block-svg{width:60%;height:60%}.icon-block-svg svg{width:100%;height:100%}.icon-block-img{width:60%;height:60%;object-fit:contain}.icon-placeholder{background:none;border:none;opacity:.5;cursor:pointer;font-size:12px;transition:opacity .2s ease}.icon-placeholder:hover{opacity:.7}.text-block{flex:0 1 420px;line-height:1.5;max-width:420px;transition:color .3s ease;white-space:normal;word-break:break-word}.rtf-content{white-space:pre-wrap;word-break:break-word;overflow-wrap:anywhere}.text-block.align-left{text-align:left}.text-block.align-right{text-align:right}.text-placeholder{opacity:.5;font-style:italic}@media (max-width: 768px){.illustration-card{flex-direction:column}.icon-block{width:64px;height:64px}.text-block{text-align:center!important;font-size:16px}}@media (min-width: 769px){.icon-block{width:84px;height:84px}.text-block{font-size:18px}.illustration-card.layout-horizontal{flex-direction:row}.illustration-card.layout-reverse{flex-direction:row-reverse}}.illustration-card.export-mode{animation:none;transition:none}.icon-library-overlay{position:fixed;bottom:60px;left:50%;transform:translate(-50%);background:#fff;color:#111827;border:1px solid #D1D5DB;border-radius:var(--oc-radius);padding:16px;max-width:600px;max-height:400px;overflow-y:auto;box-shadow:0 10px 25px #0000001a;z-index:1000;animation:slideUp .2s ease}.icon-library-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.icon-library-title{color:var(--oc-ink);margin:0;font-size:16px;font-weight:600}.icon-library-close{background:none;border:none;color:#111827;font-size:20px;cursor:pointer;padding:4px;border-radius:4px;transition:background-color .2s ease}.icon-library-close:hover{background-color:var(--oc-panel-muted)}.png-note{background-color:var(--oc-accent);color:var(--oc-panel);padding:8px 12px;border-radius:8px;margin-bottom:12px;font-size:14px;animation:fadeIn .3s ease}.icon-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:12px}.icon-upload-button{aspect-ratio:1;background-color:#f3f4f6;border:2px dashed #9CA3AF;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;color:#6b7280;transition:all .2s ease}.icon-upload-button:hover{border-color:var(--oc-accent);color:var(--oc-accent);transform:scale(1.05)}.icon-upload-plus{font-size:24px;margin-bottom:4px}.icon-upload-text{font-size:11px}.icon-grid-item{aspect-ratio:1;border:none;border-radius:8px;padding:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;position:relative;transition:all .2s ease}.icon-grid-item.inactive{background-color:#f3f4f6}.icon-grid-item.active{background-color:var(--oc-accent)}.icon-grid-item:hover:not(.active){background-color:#e5e7eb;transform:scale(1.05)}.icon-grid-svg{color:#111827;width:100%;height:100%}.icon-grid-svg svg{width:100%;height:100%}.icon-grid-img{width:100%;height:100%;object-fit:contain}.icon-png-badge{position:absolute;top:4px;right:4px;background-color:#00000080;color:#fff;font-size:8px;padding:2px 4px;border-radius:4px;font-weight:700}.icon-library-hidden-input{display:none}.icon-library-overlay::-webkit-scrollbar{width:6px}.icon-library-overlay::-webkit-scrollbar-track{background:#f3f4f6}.icon-library-overlay::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.icon-library-overlay::-webkit-scrollbar-thumb:hover{background:var(--oc-ink-muted)}@media (max-width: 768px){.icon-library-overlay{max-width:calc(100vw - 32px);max-height:300px}.icon-grid{grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:8px}}.illustration-toolbar{position:absolute;bottom:0;left:0;right:0;height:60px;background:#e5e7eb;border-top:1px solid #D1D5DB;display:flex;align-items:center;justify-content:flex-start;gap:12px;padding:0 24px;z-index:10}.toolbar-button{width:40px;height:40px;background:#fff;border:1px solid #D1D5DB;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;color:#374151;position:relative;font-size:0}.toolbar-button.active{background:var(--oc-accent);border-color:var(--oc-accent);color:#fff}.toolbar-button:disabled{opacity:.5;cursor:not-allowed}.toolbar-color-button{width:36px;height:36px;display:flex;align-items:center;justify-content:center}.illustration-toolbar .toolbar-button:before,.illustration-toolbar .align-button:before{content:"";width:20px;height:20px;display:block;background-repeat:no-repeat;background-position:center;background-size:contain}.toolbar-color-button:before{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'><circle cx='12' cy='12' r='10'/><path d='M12 2a10 10 0 0 1 0 20'/></svg>")}button[aria-label="Decrease icon size"]:before{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'><line x1='5' y1='12' x2='19' y2='12'/></svg>")}button[aria-label="Increase icon size"]:before{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'><line x1='12' y1='5' x2='12' y2='19'/><line x1='5' y1='12' x2='19' y2='12'/></svg>")}button[aria-label="Icon library"]:before{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'><rect x='3' y='3' width='18' height='18' rx='2'/><circle cx='8.5' cy='8.5' r='1.5'/><polyline points='21 15 16 10 5 21'/></svg>")}button[aria-label="Aspect ratio"]:before{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'><rect x='3' y='3' width='18' height='18' rx='2'/><rect x='7' y='7' width='10' height='10' rx='1' stroke-dasharray='2 2'/></svg>")}.align-button.left:before{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'><line x1='3' y1='6' x2='21' y2='6'/><line x1='3' y1='12' x2='15' y2='12'/><line x1='3' y1='18' x2='18' y2='18'/></svg>")}.align-button.right:before{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'><line x1='3' y1='6' x2='21' y2='6'/><line x1='9' y1='12' x2='21' y2='12'/><line x1='6' y1='18' x2='21' y2='18'/></svg>")}.illustration-toolbar .toolbar-popup{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:#fff;color:#111827;border:1px solid #D1D5DB;border-radius:8px;padding:8px;margin-bottom:8px;box-shadow:0 10px 25px #0000001a;animation:slideUp .2s ease}.color-swatch{width:24px;height:24px;border:none;border-radius:4px;cursor:pointer;transition:transform .2s ease}.aspect-menu{min-width:120px}.illustration-toolbar .aspect-option{display:block;width:100%;padding:8px 16px;background:none;border:none;color:#111827;cursor:pointer;text-align:left;border-radius:4px;margin-bottom:4px;transition:background-color .2s ease}.illustration-toolbar .aspect-option:hover{background-color:var(--oc-panel-muted)}.illustration-toolbar .aspect-option.active{background-color:var(--oc-accent);color:#fff;font-weight:700}.align-toggle-group{display:flex;gap:4px}.align-button{padding:0;width:40px;height:40px;border:1px solid #D1D5DB;border-radius:8px;background:#fff;color:#374151;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;font-size:0!important;line-height:0!important;color:transparent}.align-button:hover{background:#f9fafb;border-color:#9ca3af;transform:translateY(-1px)}.align-button.left{border-radius:4px 0 0 4px}.align-button.right{border-radius:0 4px 4px 0}.align-button.inactive{background-color:#fff;border-color:#d1d5db}.align-button.active{background-color:var(--oc-accent);color:var(--oc-panel);font-weight:700;border-color:var(--oc-accent)}@media (max-width: 768px){.illustration-toolbar{gap:12px;padding:0 12px}.toolbar-button{font-size:18px;padding:6px}}.illustrations-view{display:flex;height:100%;width:100%;background-color:var(--oc-bg)}.illustrations-left-panel{min-width:520px;background:var(--oc-panel);color:var(--oc-ink);padding:48px 40px;overflow-y:auto;display:flex;flex-direction:column;gap:32px}.illustrations-panel-title{color:var(--oc-ink);font-size:18px;margin:0;font-weight:600}.illustrations-control-group{display:flex;flex-direction:column;gap:8px}.illustrations-control-group>div{min-width:0}.illustrations-label{color:var(--oc-ink);font-size:14px;font-weight:500;display:block}.illustrations-textarea{width:100%;min-height:80px;padding:12px;background-color:var(--oc-panel);color:var(--oc-ink);border:1px solid var(--oc-panel-muted);border-radius:8px;box-sizing:border-box;font-family:inherit;font-size:14px;transition:border-color .2s ease}.illustrations-textarea:focus{outline:none;border-color:var(--oc-accent)}.illustrations-textarea.error{border-color:#f44}.illustrations-textarea.rtf{display:block;width:100%;white-space:pre-wrap;outline:none;overflow-y:auto;overflow-x:hidden;max-width:100%;word-break:break-all;overflow-wrap:anywhere;contain:inline-size}.illustrations-textarea.rtf:empty:before{content:attr(data-placeholder);color:var(--oc-ink-muted)}.rtf-toolbar{display:flex;gap:8px;margin-bottom:8px}.rtf-toolbar button{padding:6px 10px;border:1px solid var(--oc-panel-muted);background:var(--oc-panel);color:var(--oc-ink);border-radius:6px;cursor:pointer}.rtf-toolbar button:hover{border-color:var(--oc-accent)}.illustrations-char-counter{margin-top:4px;display:flex;justify-content:space-between;font-size:12px}.illustrations-char-count{color:var(--oc-ink-muted)}.illustrations-char-count.error{color:#f44}.illustrations-char-min{color:#f84}.illustrations-bg-options{display:flex;gap:8px}.illustrations-bg-button{flex:1;padding:12px;border:1px solid var(--oc-panel-muted);border-radius:8px;cursor:pointer;font-size:12px;font-weight:400;transition:all .2s ease}.illustrations-bg-button.white{background-color:#fff;color:#000}.illustrations-bg-button.dark{background-color:#343434;color:#fff}.illustrations-bg-button.transparent{background-image:repeating-conic-gradient(#808080 0% 25%,transparent 0% 50%);background-size:20px 20px;background-position:0 0;color:#000}.illustrations-bg-button.active{border:2px solid var(--oc-accent);font-weight:700}.illustrations-bg-button:hover:not(.active){transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.illustrations-visual-helper{padding:12px;background-color:var(--oc-panel);border-radius:8px;font-size:12px;color:var(--oc-ink-muted);line-height:1.5}.illustrations-format-buttons{display:flex;gap:8px;margin-bottom:8px}.illustrations-format-button{padding:2px 6px;background-color:var(--oc-panel-muted);border-radius:3px;border:none;color:var(--oc-ink);cursor:default}.illustrations-format-note{opacity:.6;font-size:11px}.illustrations-canvas-area{flex:1;display:flex;align-items:center;justify-content:center;padding:48px 48px 100px;background-color:#f5f5f5;position:relative;overflow:auto}.illustrations-canvas-wrapper{max-width:800px;width:100%;box-shadow:0 4px 12px #0000001a;border-radius:var(--oc-radius);overflow:hidden;background:#fff}@media (max-width: 768px){.illustrations-view{flex-direction:column}.illustrations-left-panel{width:100%;max-height:40vh}.illustrations-canvas-area{padding:24px 24px 80px}}.illustrations-textarea.rtf *{margin:0;padding:0;max-width:100%}.illustrations-control-group select{padding:10px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--oc-ink);font-size:14px;transition:all .2s;cursor:pointer}.illustrations-control-group select:focus{outline:none;border-color:var(--oc-accent);background:#ffffff14}.illustrations-select{padding:10px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--oc-ink);font-size:14px;transition:all .2s;cursor:pointer}.illustrations-select:focus{outline:none;border-color:var(--oc-accent);background:#ffffff14}.quote-card{width:100%;display:flex;align-items:center;justify-content:center;padding:48px;box-sizing:border-box;border:1px solid rgba(0,0,0,.1);border-radius:var(--oc-radius);transition:background-color .3s ease}.quote-card.bg-white{background-color:#fff}.quote-card.bg-dark{background-color:#44403e}.quote-card.bg-transparent{background-image:repeating-conic-gradient(#f0f0f0,#f0f0f0 25%,#fff 0%,#fff 50%);background-size:20px 20px;border:1px solid rgba(0,0,0,.2)}.quote-content{max-width:720px;width:100%;display:flex;flex-direction:column;gap:32px}.quote-text-wrapper{position:relative}.quote-mark{position:absolute;top:-8px;left:-40px;opacity:.6}.quote-text{font-size:32px;line-height:1.4;font-weight:600;margin:0;letter-spacing:-.02em}.quote-attribution{display:flex;flex-direction:column;gap:4px}.quote-name{font-size:18px;font-weight:600;line-height:1.4}.quote-company{font-size:16px;font-weight:400;line-height:1.4}@media (max-width: 768px){.quote-card{padding:32px}.quote-content{max-width:100%}.quote-mark{width:24px;height:18px;left:-28px;top:-4px}.quote-text{font-size:24px}.quote-name{font-size:16px}.quote-company{font-size:14px}}@media (min-width: 1440px){.quote-text{font-size:36px}.quote-name{font-size:20px}.quote-company{font-size:18px}}.quote-toolbar{position:absolute;bottom:0;left:0;right:0;height:60px;background:#e5e7eb;border-top:1px solid #D1D5DB;display:flex;align-items:center;justify-content:flex-start;gap:24px;padding:0 24px;z-index:10}.toolbar-left{display:flex;align-items:center;gap:12px}.toolbar-right{margin-left:auto;display:flex;align-items:center}.toolbar-button{width:40px;height:40px;background:#fff;border:1px solid #D1D5DB;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;color:#374151;font-size:0}.toolbar-button:hover{background:#f9fafb;border-color:#9ca3af;transform:translateY(-1px)}.toolbar-button.color-button{border:1px solid #D1D5DB}.quote-toolbar .toolbar-popup{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:#fff;color:#111827;border:1px solid #D1D5DB;border-radius:8px;padding:8px;margin-bottom:8px;box-shadow:0 10px 25px #0000001a;animation:slideUp .2s ease}.quote-toolbar .aspect-option{display:block;width:100%;padding:8px 16px;background:none;border:none;color:#111827;cursor:pointer;text-align:left;border-radius:4px;margin-bottom:2px;transition:background-color .2s ease;font-size:14px}.quote-toolbar .aspect-option:hover{background-color:#f3f4f6}.quote-toolbar .aspect-option.active{background-color:var(--oc-accent);color:#fff;font-weight:600}.quote-toolbar .toolbar-button:before{content:"";width:20px;height:20px;display:block;background-repeat:no-repeat;background-position:center;background-size:contain}.quote-toolbar .color-button:before{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'><circle cx='12' cy='12' r='10'/><path d='M12 2a10 10 0 0 1 0 20'/></svg>")}.quote-toolbar button[aria-label="Aspect ratio"]:before{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'><rect x='3' y='3' width='18' height='18' rx='2'/><rect x='7' y='7' width='10' height='10' rx='1' stroke-dasharray='2 2'/></svg>")}@media (max-width: 768px){.quote-toolbar{gap:16px;padding:0 16px}.toolbar-button{font-size:18px;padding:6px}}.quotes-view{display:flex;height:100%;width:100%;background-color:var(--oc-bg)}.quotes-left-panel{width:520px;background:var(--oc-panel);color:var(--oc-ink);padding:48px 40px;overflow-y:auto;display:flex;flex-direction:column;gap:32px}.quotes-panel-title{color:var(--oc-ink);font-size:18px;margin:0;font-weight:600}.quotes-control-group{display:flex;flex-direction:column;gap:8px}.quotes-label{color:var(--oc-ink);font-size:14px;font-weight:500;display:block}.quotes-textarea{width:100%;min-height:80px;padding:12px;background-color:var(--oc-panel);color:var(--oc-ink);border:1px solid var(--oc-panel-muted);border-radius:8px;resize:vertical;font-family:inherit;font-size:14px;transition:border-color .2s ease}.quotes-textarea:focus{outline:none;border-color:var(--oc-accent)}.quotes-textarea.error{border-color:#f44}.quotes-input{width:100%;padding:12px;background-color:var(--oc-panel);color:var(--oc-ink);border:1px solid var(--oc-panel-muted);border-radius:8px;font-family:inherit;font-size:14px;transition:border-color .2s ease}.quotes-input:focus{outline:none;border-color:var(--oc-accent)}.quotes-helper{font-size:11px;color:var(--oc-ink-muted);opacity:.7}.quotes-char-counter{margin-top:4px;display:flex;justify-content:space-between;font-size:12px}.quotes-char-count{color:var(--oc-ink-muted)}.quotes-char-count.error{color:#f44}.quotes-char-min{color:#f84}.quotes-bg-options{display:grid;grid-template-columns:1fr 1fr;gap:8px}.quotes-bg-button{padding:12px;border:1px solid var(--oc-panel-muted);border-radius:8px;cursor:pointer;font-size:12px;font-weight:400;transition:all .2s ease;text-align:center}.quotes-bg-button.white{background-color:#fff;color:#000}.quotes-bg-button.dark{background-color:#44403e;color:#fff}.quotes-bg-button.accent{background-color:var(--oc-accent);color:#fff}.quotes-bg-button.transparent{background-image:repeating-conic-gradient(#808080 0% 25%,transparent 0% 50%);background-size:20px 20px;background-position:0 0;color:#000}.quotes-bg-button.active{border:2px solid var(--oc-accent);font-weight:700}.quotes-bg-button:hover:not(.active){transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.quotes-canvas-area{flex:1;display:flex;align-items:center;justify-content:center;padding:48px 48px 100px;background-color:#f5f5f5;position:relative;overflow:auto}.quotes-canvas-wrapper{max-width:900px;width:100%;box-shadow:0 4px 12px #0000001a;border-radius:var(--oc-radius);overflow:hidden}@media (max-width: 768px){.quotes-view{flex-direction:column}.quotes-left-panel{width:100%;max-height:50vh}.quotes-bg-options{grid-template-columns:1fr}.quotes-canvas-area{padding:24px 24px 80px}}.matrix-chart{width:100%;display:flex;align-items:center;justify-content:center;padding:48px;box-sizing:border-box;border-radius:var(--oc-radius);transition:background-color .3s ease}.matrix-chart.bg-white{background-color:#fff;border:1px solid rgba(0,0,0,.1)}.matrix-chart.bg-dark{background-color:#44403e;border:1px solid rgba(255,255,255,.1)}.matrix-chart.bg-transparent{background-image:repeating-conic-gradient(#f0f0f0,#f0f0f0 25%,#fff 0%,#fff 50%);background-size:20px 20px;border:1px solid rgba(0,0,0,.2)}.matrix-content{width:100%;max-width:900px;display:flex;align-items:center;justify-content:center;gap:40px}.matrix-grid-section{flex-shrink:0;display:flex;justify-content:flex-end}.matrix-grid-svg{display:block}.matrix-cell{transition:all .3s ease}.matrix-text-section{flex:0 0 auto;display:flex;flex-direction:column;align-items:flex-start;text-align:left;gap:20px}.matrix-percentage{font-size:72px;font-weight:700;line-height:1;letter-spacing:-.02em;margin:0}.matrix-body-text{font-size:18px;line-height:1.6;margin:0;max-width:400px;opacity:.9}@media (max-width: 768px){.matrix-chart{padding:32px}.matrix-content{flex-direction:column;gap:32px;align-items:center;text-align:center}.matrix-percentage{font-size:48px}.matrix-body-text{font-size:16px;max-width:100%}}@media (min-width: 1440px){.matrix-percentage{font-size:84px}.matrix-body-text{font-size:20px}}@keyframes fillCell{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.matrix-cell{animation:fillCell .3s ease forwards}.matrix-toolbar{position:absolute;bottom:0;left:0;right:0;height:60px;background:#e5e7eb;border-top:1px solid #D1D5DB;display:flex;align-items:center;padding:0 24px;gap:16px;z-index:10}.matrix-toolbar-button{width:40px;height:40px;background:#fff;border:1px solid #D1D5DB;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;color:#374151;font-size:20px}.matrix-toolbar-button:hover{background:#f9fafb;border-color:#9ca3af;transform:translateY(-1px)}.matrix-toolbar-button:active{transform:scale(.95)}.matrix-toolbar-button.color-button{border:1px solid #D1D5DB;font-size:0;position:relative}.matrix-toolbar-button.color-button:before{content:"";width:20px;height:20px;display:block;background-repeat:no-repeat;background-position:center;background-size:contain;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'><circle cx='12' cy='12' r='9.5'/></svg>")}.toolbar-popup{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background-color:var(--oc-panel);border-radius:8px;padding:8px;margin-bottom:8px;box-shadow:0 2px 8px #0003;animation:slideUp .2s ease}@media (max-width: 768px){.matrix-toolbar{padding:0 16px}.matrix-toolbar-button{font-size:20px;padding:6px;min-width:36px;min-height:36px}}.matrix-view{display:flex;height:100%;width:100%;background-color:var(--oc-bg)}.matrix-left-panel{width:520px;background:var(--oc-panel);color:var(--oc-ink);padding:48px 40px;overflow-y:auto;display:flex;flex-direction:column;gap:32px}.matrix-panel-title{color:var(--oc-ink);font-size:18px;margin:0;font-weight:600}.matrix-control-group{display:flex;flex-direction:column;gap:8px}.matrix-label{color:var(--oc-ink);font-size:14px;font-weight:500;display:block}.matrix-input{width:100%;padding:12px;background-color:var(--oc-panel);color:var(--oc-ink);border:1px solid var(--oc-panel-muted);border-radius:8px;font-family:inherit;font-size:16px;transition:border-color .2s ease}.matrix-input:focus{outline:none;border-color:var(--oc-accent)}.matrix-input.error{border-color:#f44}.matrix-textarea{width:100%;min-height:80px;padding:12px;background-color:var(--oc-panel);color:var(--oc-ink);border:1px solid var(--oc-panel-muted);border-radius:8px;resize:vertical;font-family:inherit;font-size:14px;transition:border-color .2s ease}.matrix-textarea:focus{outline:none;border-color:var(--oc-accent)}.matrix-textarea.error{border-color:#f44}.matrix-helper{font-size:11px;color:var(--oc-ink-muted);opacity:.7}.matrix-error{font-size:11px;color:#f44}.matrix-char-counter{margin-top:4px;display:flex;justify-content:space-between;font-size:12px}.matrix-char-count{color:var(--oc-ink-muted)}.matrix-char-count.error{color:#f44}.matrix-char-min{color:#f84}.matrix-bg-options{display:flex;gap:8px}.matrix-bg-button{flex:1;padding:12px;border:1px solid var(--oc-panel-muted);border-radius:8px;cursor:pointer;font-size:12px;font-weight:400;transition:all .2s ease;text-align:center}.matrix-bg-button.white{background-color:#fff;color:#000}.matrix-bg-button.dark{background-color:#44403e;color:#fff}.matrix-bg-button.transparent{background-image:repeating-conic-gradient(#808080 0% 25%,transparent 0% 50%);background-size:20px 20px;background-position:0 0;color:#000}.matrix-bg-button.active{border:2px solid var(--oc-accent);font-weight:700}.matrix-bg-button:hover:not(.active){transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.matrix-canvas-area{flex:1;display:flex;align-items:center;justify-content:center;padding:48px 48px 100px;background-color:#f5f5f5;position:relative;overflow:auto}.matrix-canvas-wrapper{width:100%;max-width:800px;box-shadow:0 4px 12px #0000001a;border-radius:var(--oc-radius);overflow:hidden}.matrix-input[type=number]::-webkit-inner-spin-button,.matrix-input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.matrix-input[type=number]{-moz-appearance:textfield}@media (max-width: 768px){.matrix-view{flex-direction:column}.matrix-left-panel{width:100%;max-height:50vh}.matrix-bg-options{flex-direction:column}.matrix-canvas-area{padding:24px 24px 80px}}.matrix-control-group select{padding:10px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--oc-ink);font-size:14px;transition:all .2s;cursor:pointer}.matrix-control-group select:focus{outline:none;border-color:var(--oc-accent);background:#ffffff14}.text-stat-card{width:100%;display:flex;align-items:center;justify-content:center;padding:48px;box-sizing:border-box;border-radius:var(--oc-radius);transition:background-color .3s ease;position:relative}.text-stat-card.preset-light{border:1px solid rgba(0,0,0,.1)}.text-stat-card.preset-dark{border:1px solid rgba(255,255,255,.1)}.text-stat-card.preset-accent{border:none}.text-stat-card.preset-transparent{border:1px solid rgba(0,0,0,.2);background-image:repeating-conic-gradient(#f0f0f0,#f0f0f0 25%,#fff 0%,#fff 50%);background-size:20px 20px}.text-stat-content{width:100%;max-width:800px;display:flex;flex-direction:column;gap:24px}.text-stat-percent{font-size:96px;font-weight:800;line-height:1;letter-spacing:-.04em;margin:0;animation:fadeInScale .4s ease}@keyframes fadeInScale{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.text-stat-body{font-size:20px;line-height:1.6;margin:0;max-width:100%;overflow-wrap:anywhere;opacity:.95}.text-stat-card.align-left{text-align:left}.text-stat-card.align-left .text-stat-content{align-items:flex-start}.text-stat-card.align-center{text-align:center}.text-stat-card.align-center .text-stat-content{align-items:center}.text-stat-card.align-right{text-align:right}.text-stat-card.align-right .text-stat-content{align-items:flex-end}@media (max-width: 768px){.text-stat-card{padding:32px}.text-stat-percent{font-size:64px}.text-stat-body{font-size:16px}}@media (min-width: 1440px){.text-stat-percent{font-size:120px}.text-stat-body{font-size:24px}}.text-stat-percent{transition:color .3s ease,font-size .3s ease}.text-stat-percent.placeholder{opacity:.45}.text-stat-card.export-mode{background:transparent!important}.text-stat-toolbar{position:absolute;bottom:0;left:0;right:0;height:60px;background:#e5e7eb;border-top:1px solid #D1D5DB;display:flex;align-items:center;padding:0 24px;gap:16px;z-index:10}.toolbar-right{margin-left:auto}.toolbar-control{position:relative}.text-stat-toolbar-button{width:40px;height:40px;background:#fff;border:1px solid #D1D5DB;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;color:#374151;font-size:20px}.text-stat-toolbar-button:hover:not(.disabled){background:#f9fafb;border-color:#9ca3af;transform:translateY(-1px)}.text-stat-toolbar-button.color-button{border:1px solid #D1D5DB;font-size:0;position:relative}.text-stat-toolbar-button.disabled{opacity:.5;cursor:not-allowed}.align-button-group{display:flex;background:#f3f4f6;border:1px solid #D1D5DB;border-radius:8px;padding:2px;gap:2px}.align-button{background:#fff;border:1px solid transparent;color:#374151;cursor:pointer;padding:6px 12px;border-radius:6px;font-size:16px;transition:all .2s ease;min-width:36px}.align-button:hover{background:#f9fafb}.align-button.active{background:var(--oc-accent);color:#fff;border-color:var(--oc-accent);font-weight:600}.text-stat-toolbar .toolbar-popup{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:#fff;color:#111827;border:1px solid #D1D5DB;border-radius:8px;padding:8px;margin-bottom:8px;box-shadow:0 2px 8px #0003;animation:slideUp .2s ease}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.aspect-menu{min-width:100px}.aspect-option{display:block;width:100%;padding:8px 16px;background:none;border:none;color:#111827;cursor:pointer;text-align:left;border-radius:4px;margin-bottom:2px;transition:background-color .2s ease;font-size:14px}.aspect-option:hover{background-color:#f3f4f6}.aspect-option.active{background-color:var(--oc-accent);color:#fff;font-weight:600}button[aria-label="Aspect ratio"]{font-size:0;position:relative}button[aria-label="Aspect ratio"]:before{content:"";width:20px;height:20px;display:block;background-repeat:no-repeat;background-position:center;background-size:contain;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'><rect x='3' y='3' width='18' height='18' rx='2'/><rect x='7' y='7' width='10' height='10' rx='1' stroke-dasharray='2 2'/></svg>")}.text-stat-toolbar-button.color-button:before{content:"";width:20px;height:20px;display:block;background-repeat:no-repeat;background-position:center;background-size:contain;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'><circle cx='12' cy='12' r='9.5'/></svg>")}.align-button{font-size:0;line-height:0;color:transparent;display:flex;align-items:center;justify-content:center}.align-button:before{content:"";width:20px;height:20px;display:block;background-repeat:no-repeat;background-position:center;background-size:contain}button[aria-label="Align left"]:before{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'><line x1='3' y1='6' x2='21' y2='6'/><line x1='3' y1='12' x2='15' y2='12'/><line x1='3' y1='18' x2='18' y2='18'/></svg>")}button[aria-label="Align center"]:before{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'><line x1='3' y1='6' x2='21' y2='6'/><line x1='6' y1='12' x2='18' y2='12'/><line x1='3' y1='18' x2='21' y2='18'/></svg>")}button[aria-label="Align right"]:before{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'><line x1='3' y1='6' x2='21' y2='6'/><line x1='9' y1='12' x2='21' y2='12'/><line x1='6' y1='18' x2='21' y2='18'/></svg>")}.color-swatches{display:flex;gap:4px}.color-swatch{width:28px;height:28px;border:none;border-radius:4px;cursor:pointer;transition:transform .2s ease}.color-swatch:hover{transform:scale(1.1)}.color-swatch.active{box-shadow:0 0 0 2px var(--oc-accent)}@media (max-width: 768px){.text-stat-toolbar{padding:0 16px;gap:12px}.text-stat-toolbar-button{font-size:18px;padding:6px}.align-button{padding:4px 8px;font-size:14px}}.text-charts-view{display:flex;height:100%;width:100%;background-color:var(--oc-bg)}.text-charts-left-panel{width:520px;background:var(--oc-panel);color:var(--oc-ink);padding:48px 40px;overflow-y:auto;display:flex;flex-direction:column;gap:32px}.text-charts-panel-title{color:var(--oc-ink);font-size:18px;margin:0;font-weight:600}.text-charts-control-group{display:flex;flex-direction:column;gap:8px}.text-charts-label{color:var(--oc-ink);font-size:14px;font-weight:500;display:block}.text-charts-input{width:100%;padding:12px;background-color:var(--oc-panel);color:var(--oc-ink);border:1px solid var(--oc-panel-muted);border-radius:8px;font-family:inherit;font-size:16px;transition:border-color .2s ease}.text-charts-input:focus{outline:none;border-color:var(--oc-accent)}.text-charts-input.error{border-color:#f44}.text-charts-textarea{width:100%;min-height:80px;padding:12px;background-color:var(--oc-panel);color:var(--oc-ink);border:1px solid var(--oc-panel-muted);border-radius:8px;resize:vertical;font-family:inherit;font-size:14px;transition:border-color .2s ease}.text-charts-textarea:focus{outline:none;border-color:var(--oc-accent)}.text-charts-textarea.error{border-color:#f44}.text-charts-helper{font-size:11px;color:var(--oc-ink-muted);opacity:.7}.text-charts-error{font-size:11px;color:#f44}.text-charts-char-counter{margin-top:4px;display:flex;justify-content:space-between;font-size:12px}.text-charts-char-count{color:var(--oc-ink-muted)}.text-charts-char-count.error{color:#f44}.text-charts-char-min{color:#f84}.text-charts-preset-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.text-charts-preset-button{padding:12px;border:1px solid var(--oc-panel-muted);border-radius:8px;cursor:pointer;font-size:12px;font-weight:400;transition:all .2s ease;text-align:center}.text-charts-preset-button.preset-light{background-color:#fff;color:#000}.text-charts-preset-button.preset-dark{background-color:#44403e;color:#fff}.text-charts-preset-button.preset-accent{background-color:var(--oc-accent);color:#000}.text-charts-preset-button.preset-transparent{background-image:repeating-conic-gradient(#808080 0% 25%,transparent 0% 50%);background-size:20px 20px;background-position:0 0;color:#000}.text-charts-preset-button.active{border:2px solid var(--oc-accent);font-weight:700;box-shadow:0 0 0 1px var(--oc-accent)}.text-charts-preset-button:hover:not(.active){transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.text-charts-canvas-area{flex:1;display:flex;align-items:center;justify-content:center;padding:48px 48px 100px;background-color:#f5f5f5;position:relative;overflow:auto}.text-charts-canvas-wrapper{width:100%;max-width:1000px;box-shadow:0 4px 12px #0000001a;border-radius:var(--oc-radius);overflow:hidden}.text-charts-input[type=number]::-webkit-inner-spin-button,.text-charts-input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.text-charts-input[type=number]{-moz-appearance:textfield}@media (max-width: 768px){.text-charts-view{flex-direction:column}.text-charts-left-panel{width:100%;max-height:50vh}.text-charts-preset-grid{grid-template-columns:1fr}.text-charts-canvas-area{padding:24px 24px 80px}}.help-view{display:flex;height:100vh;background:var(--oc-bg);color:var(--oc-ink)}.help-detail{flex:1;display:flex;justify-content:center;align-items:flex-start;padding:64px;overflow-y:auto}.help-detail-inner{max-width:720px;width:100%;background:#fff;border-radius:16px;box-shadow:0 12px 40px #0f172a14;padding:40px;display:flex;flex-direction:column;gap:20px}.help-detail-inner h2{margin:0;font-size:28px;font-weight:700;color:#111827}.help-detail-description{margin:0;color:#4b5563;line-height:1.6;font-size:16px}.help-detail-inner ul{margin:0;padding-left:20px;display:flex;flex-direction:column;gap:10px;color:#1f2937;line-height:1.6}.help-detail-inner li{font-size:15px}.help-detail-tips{border-left:3px solid var(--oc-accent);padding-left:16px;color:#4b5563}.help-detail-tips p{margin:0 0 8px;font-size:14px}.help-detail-tips p:last-child{margin-bottom:0}.help-sidebar{width:520px;padding:48px 40px;background:var(--oc-panel);color:var(--oc-ink);border-right:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:32px;overflow-y:auto}.help-sidebar-header h1{margin:0 0 10px;font-size:24px;font-weight:700}.help-sidebar-header p{margin:0;font-size:14px;line-height:1.6;color:#ffffffb3}.help-list{display:flex;flex-direction:column;gap:12px}.help-list-item{display:flex;flex-direction:column;align-items:flex-start;gap:4px;width:100%;text-align:left;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:var(--oc-ink);border-radius:10px;padding:14px 16px;cursor:pointer;transition:transform .2s ease,background .2s ease,border-color .2s ease}.help-list-item:hover{transform:translateY(-1px);background:#ffffff1f}.help-list-item.active{border-color:var(--oc-accent);background:#efba2b2e;box-shadow:0 0 0 2px #efba2b33 inset}.help-list-title{font-size:15px;font-weight:600}.help-list-summary{font-size:13px;color:#ffffffb3}@media (max-width: 1024px){.help-view{flex-direction:column}.help-sidebar{width:100%;border-right:none;border-bottom:1px solid rgba(255,255,255,.08)}.help-detail{padding:32px 20px}.help-detail-inner{padding:28px}}@media (max-width: 640px){.help-list-item{padding:12px 14px}.help-detail-inner h2{font-size:22px}}.contact-view{display:flex;height:100vh;background-color:var(--oc-bg)}.contact-left-panel{min-width:520px;background:var(--oc-panel);color:var(--oc-ink);padding:48px 40px;overflow-y:auto;display:flex;flex-direction:column;gap:24px}.contact-header{margin-bottom:32px}.contact-brand-info{display:flex;align-items:center;gap:12px;padding:16px;background-color:var(--oc-panel-muted);border-radius:8px;position:relative}.brand-avatar{width:40px;height:40px;background-color:var(--oc-accent);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:700;color:var(--oc-panel)}.brand-details{flex:1}.brand-details h3{color:var(--oc-ink);font-size:14px;margin:0 0 4px;font-weight:600}.brand-details p{color:var(--oc-ink-muted);font-size:12px;margin:0;text-decoration:underline;cursor:pointer}.play-button{width:40px;height:40px;border-radius:50%;background-color:#ffffff1a;border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.play-button:hover{background-color:#fff3;transform:scale(1.05)}.contact-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:var(--oc-ink);font-size:14px;font-weight:500}.form-group input,.form-group textarea{width:100%;padding:12px;background-color:#fff;border:1px solid transparent;border-radius:4px;font-family:inherit;font-size:14px;transition:all .2s ease;color:#333}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--oc-accent);box-shadow:0 0 0 3px #efba2b1a}.form-group input.error,.form-group textarea.error{border-color:#f44}.form-group input:disabled,.form-group textarea:disabled{opacity:.6;cursor:not-allowed}.form-group textarea{resize:vertical;min-height:120px}.error-message{color:#f44;font-size:12px;margin-top:-4px}.submit-button{padding:14px 32px;background-color:#fff;color:var(--oc-panel);border:none;border-radius:4px;font-size:14px;font-weight:600;letter-spacing:.5px;cursor:pointer;transition:all .2s ease;margin-top:12px}.submit-button:hover:not(:disabled){background-color:var(--oc-accent);transform:translateY(-1px);box-shadow:0 4px 8px #0003}.submit-button:active:not(:disabled){transform:translateY(0)}.submit-button:disabled{opacity:.6;cursor:not-allowed}.success-message{padding:12px;background-color:#4caf50;color:#fff;border-radius:4px;text-align:center;font-size:14px;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.contact-right-panel{flex:1;display:flex;align-items:center;justify-content:center;padding:48px;background-color:var(--oc-bg)}.contact-content{max-width:600px;width:100%}.contact-watermark{display:flex;justify-content:center;margin-bottom:48px}.contact-watermark-image{width:240px;max-width:100%;opacity:.1;filter:grayscale(100%);pointer-events:none;-webkit-user-select:none;user-select:none}.contact-info{text-align:left}.contact-intro{font-size:16px;line-height:1.7;color:#666;margin-bottom:32px}.contact-details{display:flex;flex-direction:column;gap:16px;margin-bottom:32px}.contact-item{font-size:16px;color:#333;line-height:1.5}.contact-item strong{font-weight:600}.contact-footer{padding-top:24px;border-top:1px solid #e0e0e0}.contact-footer p{font-size:16px;color:#666;line-height:1.5}@media (max-width: 768px){.contact-view{flex-direction:column}.contact-left-panel{width:100%;max-height:60vh}.contact-right-panel{padding:32px 24px}.contact-intro,.contact-item,.contact-footer p{font-size:14px}}.checkbox-wrapper{display:flex;align-items:center;gap:12px;cursor:pointer;width:100%}.checkbox-wrapper input{position:absolute;opacity:0;pointer-events:none}.checkbox{width:20px;height:20px;border:2px solid var(--oc-ink-muted);border-radius:4px;background:transparent;display:flex;align-items:center;justify-content:center;transition:all .2s}.checkbox-wrapper input:checked~.checkbox{background:var(--oc-accent);border-color:var(--oc-accent)}.checkbox-wrapper input:focus-visible~.checkbox{outline:2px solid var(--oc-accent);outline-offset:2px}.checkbox-check{display:none;color:var(--oc-panel);width:12px;height:12px}.checkbox-wrapper input:checked~.checkbox .checkbox-check{display:block}.checkbox-label{font-size:14px;color:var(--oc-ink);-webkit-user-select:none;user-select:none}.brand-picker{display:flex;flex-direction:column;gap:12px}.brand-item{display:flex;align-items:center;height:48px;padding:0 16px;background:#ffffff0d;border-radius:8px;transition:background .2s}.brand-item:hover{background:#ffffff14}.welcome-view{display:flex;height:100%;width:100%}.welcome-left{min-width:520px;background:var(--oc-panel);color:var(--oc-ink);padding:32px 40px 40px;display:flex;flex-direction:column;gap:28px}.welcome-hero{display:flex;align-items:center;gap:16px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:14px 16px}.welcome-avatar{width:40px;height:40px;border-radius:8px;background:var(--oc-bg);display:grid;place-items:center;overflow:hidden}.welcome-avatar img{width:80%;height:80%;opacity:.9}.welcome-hero-copy{display:flex;flex-direction:column;gap:2px}.welcome-greeting{font-weight:700}.welcome-sub{font-size:14px;color:var(--oc-ink-muted)}.welcome-form{display:flex;flex-direction:column;gap:18px}.welcome-form-title{font-size:18px;margin:0 0 4px}.welcome-actions{margin-top:10px}.welcome-right{position:relative;flex:1;background:var(--oc-bg)}.welcome-watermark{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:min(60%,540px);opacity:.08;-webkit-user-select:none;user-select:none;pointer-events:none;filter:grayscale(100%)}@media (max-width: 1024px){.welcome-left{min-width:420px;padding:24px}}@media (max-width: 768px){.welcome-view{flex-direction:column}.welcome-left{min-width:100%}.welcome-right{min-height:320px}}.login-screen{min-height:100vh;min-width:100vw;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at top,rgba(239,186,43,.18),transparent 55%),#111112;padding:24px;box-sizing:border-box}.login-card{width:100%;max-width:420px;background:#18181beb;border-radius:24px;padding:48px 44px 40px;border:1px solid rgba(255,255,255,.08);box-shadow:0 40px 80px #0000008c;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#f9fafb;display:flex;flex-direction:column;gap:20px}.login-logo{display:flex;align-items:center;gap:16px;font-size:22px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--oc-accent)}.login-logo svg circle{fill:var(--oc-accent)}.login-wordmark{color:#f9fafb}.login-title{font-size:28px;font-weight:600;letter-spacing:-.01em}.login-subtitle{font-size:15px;color:#f9fafbb8}.login-form{display:flex;flex-direction:column;gap:12px}.login-label{font-size:13px;text-transform:uppercase;letter-spacing:.12em;color:#f9fafb99}.login-input{margin-top:4px;width:100%;padding:14px 16px;border-radius:12px;border:1px solid rgba(17,24,39,.2);background:#fff;color:#111827;font-size:15px;transition:border-color .2s ease,box-shadow .2s ease}.login-input:focus{outline:none;border-color:var(--oc-accent);box-shadow:0 0 0 3px #efba2b33}.login-error{margin-top:4px;background:#ef44442e;color:#fecaca;border-radius:12px;padding:12px 14px;font-size:14px}.login-hint{margin-top:4px;color:#f9fafb99;font-size:13px}.login-submit{margin-top:4px;padding:14px 16px;border-radius:12px;border:none;background:var(--oc-accent);color:#1f1f1f;font-weight:600;font-size:16px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.login-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 12px 24px #efba2b59}.login-submit:disabled{cursor:wait;opacity:.7}.login-footer{margin-top:8px;font-size:13px;color:#f9fafb99;text-align:center}@media (max-width: 520px){.login-card{padding:36px 28px;border-radius:18px}.login-title{font-size:24px}}.app-container{display:flex;height:100vh;width:100vw;overflow:hidden;background:var(--oc-bg);padding-left:80px;box-sizing:border-box}.left-panel{min-width:520px;background:var(--oc-panel);color:var(--oc-ink);padding:48px 40px;display:flex;flex-direction:column}.right-canvas{flex:1;background:var(--oc-bg);position:relative;display:flex;align-items:center;justify-content:center}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%) translateY(100px);background:var(--oc-accent);color:var(--oc-panel);padding:12px 24px;border-radius:var(--oc-radius);font-weight:600;font-size:14px;box-shadow:0 4px 12px #00000026;opacity:0;transition:all .3s ease;z-index:9999;pointer-events:none}.toast.show{transform:translate(-50%) translateY(0);opacity:1}.app-container>div:not(.sidebar){animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.hidden{display:none!important}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--oc-panel)}::-webkit-scrollbar-thumb{background:var(--oc-panel-muted);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--oc-ink-muted)}button:focus-visible{outline-offset:0}.app-container>div[class*=View]:not(.brand-settings-view){width:100%;height:100%}@media (max-width: 1024px){.left-panel{min-width:400px;padding:32px 24px}}@media (max-width: 768px){.app-container{flex-direction:column}.left-panel{min-width:100%;padding:24px 16px}.toast{width:calc(100% - 48px);max-width:400px}}body.asset-exporting .donut-card.bg-transparent,body.asset-exporting .bars-card.bg-transparent,body.asset-exporting .lines-card.bg-transparent,body.asset-exporting .illustration-card.bg-transparent,body.asset-exporting .quote-card.bg-transparent,body.asset-exporting .image-overlay-container.bg-transparent,body.asset-exporting .matrix-chart.bg-transparent,body.asset-exporting .split-image-container.bg-transparent,body.asset-exporting .text-stat-card.preset-transparent{background-image:none!important}body.asset-exporting .image-overlay-container.bg-transparent,body.asset-exporting .split-image-container.bg-transparent,body.asset-exporting .text-stat-card.preset-transparent{background-color:transparent!important}.oc-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:10px 12px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background-color:#ffffff0d;color:var(--oc-ink);font-size:14px;line-height:1.4;transition:all .2s ease;cursor:pointer}.oc-select:focus{outline:none;border-color:var(--oc-accent);background-color:#ffffff14}.oc-select option{background-color:#18181bf2;color:var(--oc-ink)}.app-main{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--oc-bg)}.app-header{display:flex;align-items:center;justify-content:space-between;padding:24px 32px 16px;border-bottom:1px solid rgba(0,0,0,.06);background:#fcfdfeeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.app-header-left{display:flex;align-items:center;gap:12px;font-size:15px;color:#1f2933}.app-header-greeting{font-weight:600}.app-header-role{padding:4px 10px;border-radius:999px;background:#4f46e51f;color:#4f46e5;font-size:12px;letter-spacing:.05em;text-transform:uppercase}.app-header-error{font-size:13px;color:#b91c1c}.app-signout{padding:10px 18px;border-radius:999px;border:1px solid rgba(52,52,52,.14);background:#fff;color:#1f1f1f;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.app-signout:hover{transform:translateY(-1px);box-shadow:0 12px 24px #0000001f}.app-view{flex:1;min-height:0;position:relative}.app-loading{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#141414,#1c1c1c 45%,#242424);color:#f9fafb;font-size:18px;font-weight:600;letter-spacing:.04em}@media (max-width: 768px){.app-header{padding:20px 20px 12px;flex-wrap:wrap;gap:16px}.app-signout{width:100%}}:root{--oc-bg: #FCFDFE;--oc-rail: #343434;--oc-panel: #44403E;--oc-panel-muted: #605E5E;--oc-ink: #FFFFFF;--oc-ink-muted: #CFCFCF;--oc-accent: #EFBA2B;--oc-radius: 16px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden}#root{width:100vw;height:100vh}*:focus-visible{outline:2px solid var(--oc-accent);outline-offset:2px}.toast{position:fixed;bottom:24px;right:24px;background:var(--oc-panel);color:var(--oc-ink);padding:16px 24px;border-radius:8px;box-shadow:0 4px 12px #0003;transform:translateY(100px);opacity:0;transition:all .3s ease;z-index:1000}.toast.show{transform:translateY(0);opacity:1}
