.navbar{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:60px;background-color:#fff;border-bottom:1px solid var(--color-gray-200);position:sticky;top:0;z-index:100}.navbar-brand{font-size:18px;font-weight:700;color:var(--color-gray-900)}.navbar-links{display:flex;gap:8px}.navbar-link{padding:8px 16px;font-size:14px;font-weight:500;color:var(--color-gray-600);text-decoration:none;border-radius:var(--radius-md);transition:background-color .15s,color .15s}.navbar-link:hover{background-color:var(--color-gray-100);color:var(--color-gray-900);text-decoration:none}.navbar-link.active{background-color:var(--color-primary);color:#fff}.navbar-logout{padding:8px 16px;font-size:14px;font-weight:500;color:var(--color-gray-600);background:none;border:1px solid var(--color-gray-300);border-radius:var(--radius-md);transition:background-color .15s,border-color .15s}.navbar-logout:hover{background-color:var(--color-gray-100);border-color:var(--color-gray-400)}.layout{min-height:100vh;display:flex;flex-direction:column}.layout-content{flex:1;padding:24px;max-width:1200px;width:100%;margin:0 auto}.loading{border:2px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.loading--sm{width:16px;height:16px}.loading--md{width:24px;height:24px}.loading--lg{width:40px;height:40px;border-width:3px}.loading-fullscreen{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background-color:var(--color-gray-50)}@keyframes spin{to{transform:rotate(360deg)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:500;border:none;border-radius:var(--radius-md);transition:background-color .15s,opacity .15s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--sm{padding:6px 12px;font-size:13px}.btn--md{padding:10px 16px;font-size:14px}.btn--lg{padding:12px 24px;font-size:16px}.btn--primary{background-color:var(--color-primary);color:#fff}.btn--primary:hover:not(:disabled){background-color:var(--color-primary-dark)}.btn--secondary{background-color:var(--color-gray-200);color:var(--color-gray-700)}.btn--secondary:hover:not(:disabled){background-color:var(--color-gray-300)}.btn--danger{background-color:var(--color-danger);color:#fff}.btn--danger:hover:not(:disabled){background-color:var(--color-danger-dark)}.btn--ghost{background-color:transparent;color:var(--color-gray-600)}.btn--ghost:hover:not(:disabled){background-color:var(--color-gray-100)}.input-wrapper{display:flex;flex-direction:column;gap:4px}.input-label{font-size:14px;font-weight:500;color:var(--color-gray-700)}.input{padding:10px 12px;font-size:14px;border:1px solid var(--color-gray-300);border-radius:var(--radius-md);background-color:#fff;transition:border-color .15s,box-shadow .15s}.input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a}.input--error{border-color:var(--color-danger)}.input--error:focus{box-shadow:0 0 0 3px #dc26261a}.input-error{font-size:12px;color:var(--color-danger)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.login-card{width:100%;max-width:400px;padding:40px;background-color:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.login-title{font-size:24px;font-weight:700;color:var(--color-gray-900);text-align:center;margin-bottom:8px}.login-subtitle{font-size:14px;color:var(--color-gray-500);text-align:center;margin-bottom:32px}.login-form{display:flex;flex-direction:column;gap:20px}.login-button{width:100%}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background-color:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:500px;max-height:90vh;overflow:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--color-gray-200)}.modal-title{font-size:18px;font-weight:600;color:var(--color-gray-900)}.modal-close{background:none;border:none;font-size:24px;color:var(--color-gray-500);line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}.modal-close:hover{background-color:var(--color-gray-100);color:var(--color-gray-700)}.modal-content{padding:20px}.templates-page{display:flex;flex-direction:column;gap:24px}.templates-header{display:flex;align-items:center;justify-content:space-between}.templates-header h1{font-size:24px;font-weight:600;color:var(--color-gray-900)}.templates-loading,.templates-error,.templates-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:var(--color-gray-500);gap:16px;background-color:#fff;border-radius:var(--radius-lg)}.templates-error p{color:var(--color-danger)}.templates-table-wrapper{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;overflow-x:auto}.templates-table{width:100%;border-collapse:collapse;font-size:14px}.templates-table th,.templates-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--color-gray-100)}.templates-table th{font-weight:600;color:var(--color-gray-700);background-color:var(--color-gray-50);white-space:nowrap}.templates-table tbody tr:hover{background-color:var(--color-gray-50)}.templates-table tbody tr:last-child td{border-bottom:none}.cell-name{font-weight:500;color:var(--color-gray-900)}.cell-url code{font-family:var(--font-mono);font-size:12px;padding:2px 6px;background-color:var(--color-gray-100);border-radius:var(--radius-sm);color:var(--color-gray-700)}.cell-count{font-family:var(--font-mono)}.text-muted{color:var(--color-gray-400);font-style:italic}.status-badge{display:inline-block;padding:4px 8px;border-radius:9999px;font-size:12px;font-weight:500}.status-active{background-color:#dcfce7;color:#166534}.status-inactive{background-color:var(--color-gray-100);color:var(--color-gray-600)}.cell-actions{white-space:nowrap}.cell-actions>.action-btn{width:max-content}.action-btn{padding:6px 12px;font-size:13px;font-weight:500;background:none;border:1px solid var(--color-gray-300);border-radius:var(--radius-sm);margin-right:8px;transition:all .15s;cursor:pointer}.action-btn:last-child{margin-right:0}.action-edit{color:var(--color-primary);border-color:var(--color-primary)}.action-edit:hover{background-color:var(--color-primary);color:#fff}.action-toggle{color:var(--color-warning);border-color:var(--color-warning)}.action-toggle:hover{background-color:var(--color-warning);color:#fff}.action-delete{color:var(--color-danger);border-color:var(--color-danger)}.action-delete:hover{background-color:var(--color-danger);color:#fff}.create-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:14px;font-weight:500;color:var(--color-gray-700)}.form-input{padding:10px 12px;font-size:14px;border:1px solid var(--color-gray-300);border-radius:var(--radius-md)}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a}.form-error{padding:10px 12px;background-color:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-md);color:var(--color-danger);font-size:13px}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:8px}@media(max-width:768px){.templates-header{flex-direction:column;align-items:flex-start;gap:16px}.templates-table{font-size:13px}.templates-table th,.templates-table td{padding:10px 12px}.action-btn{padding:4px 8px;font-size:12px;margin-right:4px}}.url-section{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px;margin-bottom:24px}.url-builder{display:flex;align-items:flex-end;gap:4px;flex-wrap:wrap;margin-bottom:12px}.url-part{display:flex;flex-direction:column;gap:6px}.url-label{font-size:11px;font-weight:500;text-transform:uppercase;color:var(--color-gray-500)}.url-prefix code,.url-suffix code{padding:10px 12px;font-family:var(--font-mono);font-size:13px;background-color:var(--color-gray-100);border-radius:var(--radius-md);color:var(--color-gray-600);white-space:nowrap}.url-input{padding:10px 12px;font-family:var(--font-mono);font-size:13px;border:2px solid var(--color-primary);border-radius:var(--radius-md);min-width:200px}.url-input:focus{outline:none;box-shadow:0 0 0 3px #2563eb33}.url-input--error{border-color:var(--color-danger)}.url-input--error:focus{box-shadow:0 0 0 3px #dc262633}.url-error{color:var(--color-danger);font-size:13px;margin-bottom:12px}.url-preview{display:flex;align-items:center;gap:8px;padding:12px;background-color:var(--color-gray-50);border-radius:var(--radius-md);margin-bottom:16px;overflow-x:auto}.url-preview-label{font-size:13px;font-weight:500;color:var(--color-gray-600);white-space:nowrap}.url-preview-value{font-family:var(--font-mono);font-size:13px;color:var(--color-gray-900);word-break:break-all}.url-params{display:flex;align-items:center;gap:12px;margin-bottom:20px}.url-params-label{font-size:14px;font-weight:500;color:var(--color-gray-700)}.url-params-list{display:flex;flex-wrap:wrap;gap:8px}.url-param-badge{display:inline-block;padding:6px 12px;font-size:13px;font-weight:500;font-family:var(--font-mono);color:#fff;border-radius:9999px}.url-help{padding:16px;background-color:#f0f9ff;border-radius:var(--radius-md);border-left:4px solid var(--color-primary)}.url-help h4{font-size:14px;font-weight:600;color:var(--color-gray-900);margin-bottom:8px}.url-help ul{list-style:none;display:flex;flex-direction:column;gap:6px}.url-help li{font-size:13px;color:var(--color-gray-700)}.url-help code{font-family:var(--font-mono);padding:2px 6px;background-color:#2563eb1a;border-radius:var(--radius-sm);color:var(--color-primary-dark)}@media(max-width:768px){.url-builder{flex-direction:column;align-items:stretch}.url-prefix code,.url-suffix code,.url-input{width:100%}.url-params{flex-direction:column;align-items:flex-start}}.data-entry-section{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px;margin-bottom:24px}.data-entry-section .section-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}.toggle-switch{display:flex;align-items:center;gap:8px;cursor:pointer}.toggle-switch input{display:none}.toggle-slider{width:44px;height:24px;background-color:var(--color-gray-300);border-radius:12px;position:relative;transition:background-color .2s}.toggle-slider:after{content:"";position:absolute;width:20px;height:20px;background-color:#fff;border-radius:50%;top:2px;left:2px;transition:transform .2s;box-shadow:0 1px 3px #0003}.toggle-switch input:checked+.toggle-slider{background-color:var(--color-primary)}.toggle-switch input:checked+.toggle-slider:after{transform:translate(20px)}.toggle-label{font-size:13px;font-weight:500;color:var(--color-gray-600)}.data-entry-content{display:flex;flex-direction:column;gap:20px}.field-group{display:flex;flex-direction:column;gap:8px}.field-header{display:flex;justify-content:space-between;align-items:center}.field-label{font-size:14px;font-weight:500;color:var(--color-gray-700)}.field-input{padding:10px 12px;font-size:14px;font-family:var(--font-mono);border:1px solid var(--color-gray-300);border-radius:var(--radius-md)}.field-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a}.field-error{font-size:13px;color:var(--color-danger)}.expression-hints{display:flex;flex-wrap:wrap;gap:8px;align-items:center;font-size:13px;color:var(--color-gray-500)}.expression-hint{font-family:var(--font-mono);padding:2px 8px;background-color:var(--color-gray-100);border-radius:var(--radius-sm);color:var(--color-gray-700)}.add-header-btn{padding:4px 12px;font-size:13px;font-weight:500;color:var(--color-primary);background:none;border:1px dashed var(--color-primary);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s}.add-header-btn:hover{background-color:#2563eb0d}.headers-list{display:flex;flex-direction:column;gap:8px}.header-row{display:flex;gap:8px}.header-key,.header-value{flex:1;padding:8px 12px;font-size:13px;border:1px solid var(--color-gray-300);border-radius:var(--radius-md)}.header-key:focus,.header-value:focus{outline:none;border-color:var(--color-primary)}.remove-header-btn{width:32px;height:36px;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--color-gray-400);background:none;border:none;border-radius:var(--radius-sm);cursor:pointer}.remove-header-btn:hover{color:var(--color-danger);background-color:#fef2f2}.field-hint{font-size:13px;color:var(--color-gray-500);margin-bottom:8px}.test-values-list{display:flex;flex-direction:column;gap:12px}.test-value-row{display:flex;align-items:center;gap:12px}.test-value-label{min-width:160px;font-family:var(--font-mono);font-size:13px;color:var(--color-gray-600);background-color:var(--color-gray-100);padding:8px 12px;border-radius:var(--radius-md)}.test-value-input{flex:1;padding:8px 12px;font-size:14px;border:1px solid var(--color-gray-300);border-radius:var(--radius-md)}.test-value-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a}.test-value-input::placeholder{color:var(--color-gray-400)}.test-section{display:flex;flex-direction:column;gap:12px}.test-hint{font-size:13px;color:var(--color-gray-500);font-style:italic}.test-error{padding:12px 16px;background-color:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-md);color:var(--color-danger);font-size:13px}.test-error-message{font-weight:500;margin-bottom:4px}.test-error-status{font-size:12px;color:#991b1b;margin-bottom:8px}.test-error-details{margin-top:8px;margin-bottom:8px}.test-error-details summary{cursor:pointer;font-size:13px;font-weight:500;color:#991b1b}.test-error-details pre{margin-top:8px;padding:12px;background-color:#fff5f5;border-radius:var(--radius-md);font-size:11px;overflow-x:auto;max-height:150px;color:#7f1d1d}.curl-command{margin-top:12px}.curl-command p{font-weight:500;margin-bottom:8px}.curl-command code{display:block;padding:12px;background-color:#1f2937;color:#f3f4f6;border-radius:var(--radius-md);font-family:var(--font-mono);font-size:12px;overflow-x:auto}.test-success{padding:12px 16px;background-color:#dcfce7;border:1px solid #86efac;border-radius:var(--radius-md)}.test-success-label{font-size:14px;font-weight:500;color:#166534}.test-success-meta{font-weight:400;font-size:13px;color:#15803d}.response-details{margin-top:12px}.response-details summary{cursor:pointer;font-size:13px;color:#166534}.response-details pre{margin-top:8px;padding:12px;background-color:#f0fdf4;border-radius:var(--radius-md);font-size:12px;overflow-x:auto;max-height:200px}.response-paths{padding:16px;background-color:#f0f9ff;border-radius:var(--radius-md);border-left:4px solid var(--color-primary)}.paths-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:16px}.paths-title{font-size:14px;font-weight:600;color:var(--color-gray-900);margin:0}.paths-filter{flex:1;max-width:280px;padding:6px 12px;font-size:13px;border:1px solid var(--color-gray-300);border-radius:var(--radius-md);background-color:#fff}.paths-filter:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #2563eb1a}.paths-filter::placeholder{color:var(--color-gray-400)}.paths-list{display:flex;flex-wrap:wrap;gap:8px}.path-badge{display:inline-block;padding:4px 10px;font-family:var(--font-mono);font-size:12px;background-color:#fff;border:1px solid var(--color-gray-200);border-radius:var(--radius-sm);color:var(--color-gray-700)}@media(max-width:640px){.data-entry-section .section-header{flex-direction:column;gap:16px}.header-row{flex-direction:column}.remove-header-btn{align-self:flex-end}}.element-tree{display:flex;flex-direction:column;background-color:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);min-width:200px;max-width:280px;height:fit-content;max-height:400px;overflow:hidden}.tree-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background-color:#fff;border-bottom:1px solid var(--color-gray-200)}.tree-title{font-size:12px;font-weight:600;text-transform:uppercase;color:var(--color-gray-500)}.tree-content{overflow-y:auto;padding:8px 0}.tree-node{display:flex;flex-direction:column}.tree-item{display:flex;align-items:center;gap:6px;padding:6px 12px;cursor:pointer;transition:background-color .15s;-webkit-user-select:none;user-select:none}.tree-item:hover{background-color:var(--color-gray-100)}.tree-item--selected{background-color:var(--color-primary-light, #dbeafe)!important}.tree-item--root{font-weight:500}.tree-toggle{display:flex;align-items:center;justify-content:center;width:16px;height:16px;padding:0;border:none;background:none;color:var(--color-gray-500);font-size:8px;cursor:pointer;flex-shrink:0}.tree-toggle:hover{color:var(--color-gray-700)}.tree-toggle-placeholder{width:16px;height:16px;flex-shrink:0}.tree-icon{font-size:12px;color:var(--color-gray-500);width:16px;text-align:center;flex-shrink:0}.tree-label{font-size:13px;color:var(--color-gray-700);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tree-item--selected .tree-label{color:var(--color-primary);font-weight:500}.tree-children{display:flex;flex-direction:column}.tree-empty{padding:16px 12px;font-size:12px;color:var(--color-gray-400);text-align:center}.bg-picker{display:flex;flex-direction:column;gap:8px}.bg-preview{width:100%;height:80px;border:1px solid var(--color-gray-200);border-radius:var(--radius-sm);overflow:hidden;background-color:var(--color-gray-100);background-image:linear-gradient(45deg,#ccc 25%,transparent 25%),linear-gradient(-45deg,#ccc 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#ccc 75%),linear-gradient(-45deg,transparent 75%,#ccc 75%);background-size:10px 10px;background-position:0 0,0 5px,5px -5px,-5px 0px}.bg-preview img{width:100%;height:100%;object-fit:contain}.bg-options{display:flex;gap:6px}.bg-select{flex:1;padding:6px 8px;font-size:12px;border:1px solid var(--color-gray-300);border-radius:var(--radius-sm);background-color:#fff;cursor:pointer}.bg-select:focus{outline:none;border-color:var(--color-primary)}.bg-btn{padding:6px 10px;font-size:12px;font-weight:500;color:var(--color-gray-700);background-color:#fff;border:1px solid var(--color-gray-300);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s}.bg-btn:hover:not(:disabled){background-color:var(--color-gray-50);border-color:var(--color-gray-400)}.bg-btn:disabled{opacity:.5;cursor:not-allowed}.bg-btn--primary{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.bg-btn--primary:hover:not(:disabled){background-color:var(--color-primary-dark, #1d4ed8)}.bg-btn--secondary{background-color:var(--color-gray-100)}.bg-clear{padding:6px 10px;font-size:11px;color:var(--color-danger);background:none;border:1px solid var(--color-danger);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s}.bg-clear:hover:not(:disabled){background-color:var(--color-danger);color:#fff}.bg-error{font-size:11px;color:var(--color-danger);padding:4px 0}.bg-loading{font-size:11px;color:var(--color-gray-500);padding:4px 0}.bg-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.bg-modal{background-color:#fff;border-radius:var(--radius-lg);box-shadow:0 20px 25px -5px #0000001a;width:100%;max-width:400px;margin:16px}.bg-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--color-gray-200)}.bg-modal-header h4{margin:0;font-size:16px;font-weight:600;color:var(--color-gray-900)}.bg-modal-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--color-gray-500);background:none;border:none;border-radius:var(--radius-sm);cursor:pointer}.bg-modal-close:hover{background-color:var(--color-gray-100);color:var(--color-gray-700)}.bg-modal-body{padding:16px}.bg-url-input{width:100%;padding:10px 12px;font-size:14px;border:1px solid var(--color-gray-300);border-radius:var(--radius-sm);box-sizing:border-box}.bg-url-input:focus{outline:none;border-color:var(--color-primary)}.bg-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 16px;border-top:1px solid var(--color-gray-200);background-color:var(--color-gray-50);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.properties-panel{background-color:var(--color-gray-50);border-radius:var(--radius-md);border:1px solid var(--color-gray-200);height:fit-content;max-height:600px;overflow-y:auto;min-width:280px}.properties-panel--empty{padding:40px 20px;text-align:center;color:var(--color-gray-400)}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--color-gray-200);background-color:#fff;position:sticky;top:0;z-index:1}.panel-title{font-size:14px;font-weight:600;color:var(--color-gray-900);margin:0}.delete-btn{padding:4px 10px;font-size:12px;font-weight:500;color:var(--color-danger);background:none;border:1px solid var(--color-danger);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s}.delete-btn:hover{background-color:var(--color-danger);color:#fff}.panel-content{padding:8px;display:flex;flex-direction:column;gap:4px}.prop-group{background-color:#fff;border:1px solid var(--color-gray-200);border-radius:var(--radius-sm);overflow:hidden}.prop-group-header{display:flex;align-items:center;gap:6px;padding:10px 12px;background-color:var(--color-gray-50);border-bottom:1px solid transparent}.prop-group-header--clickable{cursor:pointer;-webkit-user-select:none;user-select:none}.prop-group-header--clickable:hover{background-color:var(--color-gray-100)}.prop-group--expanded .prop-group-header{border-bottom-color:var(--color-gray-200)}.prop-group-toggle{font-size:8px;color:var(--color-gray-500);width:12px}.prop-group-title{font-size:12px;font-weight:600;color:var(--color-gray-700);text-transform:uppercase}.prop-group-content{padding:12px;display:flex;flex-direction:column;gap:10px}.property-group{display:flex;flex-direction:column;gap:4px}.property-group--half{flex:1;min-width:0}.property-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.property-label{font-size:11px;font-weight:500;color:var(--color-gray-600)}.property-input,.property-select,.property-textarea{padding:7px 10px;font-size:13px;border:1px solid var(--color-gray-300);border-radius:var(--radius-sm);background-color:#fff;width:100%;box-sizing:border-box}.property-textarea{resize:vertical;font-family:inherit;min-height:60px}.property-input:focus,.property-select:focus,.property-textarea:focus{outline:none;border-color:var(--color-primary)}.property-input:disabled,.property-select:disabled{background-color:var(--color-gray-100);color:var(--color-gray-500);cursor:not-allowed}.property-input-wrap{display:flex;align-items:center;gap:4px}.property-input-wrap .property-input{flex:1}.property-suffix{font-size:12px;color:var(--color-gray-500)}.property-color-group{display:flex;gap:8px}.property-color{width:36px;height:36px;padding:0;border:1px solid var(--color-gray-300);border-radius:var(--radius-sm);cursor:pointer;flex-shrink:0}.property-color::-webkit-color-swatch-wrapper{padding:2px}.property-color::-webkit-color-swatch{border-radius:2px;border:none}.property-color-group .property-input{flex:1}.property-hint{font-size:10px;color:var(--color-gray-500);margin-top:2px;word-break:break-all}.panel-actions{padding:12px;border-top:1px solid var(--color-gray-200);margin-top:8px}.action-btn{width:100%;padding:10px 16px;font-size:13px;font-weight:500;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s}.action-btn--secondary{background-color:#fff;border:1px solid var(--color-gray-300);color:var(--color-gray-700)}.action-btn--secondary:hover{background-color:var(--color-gray-50);border-color:var(--color-gray-400)}@media(max-width:1024px){.properties-panel{max-height:none;order:3;min-width:100%}}.properties-panel::-webkit-scrollbar{width:6px}.properties-panel::-webkit-scrollbar-track{background:var(--color-gray-100)}.properties-panel::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:3px}.properties-panel::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}.html-preview{display:flex;flex-direction:column;height:100%;min-height:400px;background-color:#1e1e1e;border-radius:var(--radius-md);overflow:hidden}.html-preview-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background-color:#2d2d2d;border-bottom:1px solid #3d3d3d}.html-preview-title{font-size:12px;font-weight:600;text-transform:uppercase;color:#888}.html-copy-btn{padding:6px 12px;font-size:12px;font-weight:500;color:#fff;background-color:#06c;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background-color .15s}.html-copy-btn:hover{background-color:#05a}.html-preview-content{flex:1;overflow:auto;padding:16px}.html-code{margin:0;font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;font-size:13px;line-height:1.6;color:#d4d4d4;white-space:pre;tab-size:2}.html-code code{font-family:inherit}.html-empty{display:flex;align-items:center;justify-content:center;height:100%;color:#666;font-size:14px}.hl-tag{color:#569cd6}.hl-attr{color:#9cdcfe}.hl-string{color:#ce9178}.hl-value{color:#b5cea8}.html-preview-content::-webkit-scrollbar{width:10px;height:10px}.html-preview-content::-webkit-scrollbar-track{background:#1e1e1e}.html-preview-content::-webkit-scrollbar-thumb{background:#3d3d3d;border-radius:5px}.html-preview-content::-webkit-scrollbar-thumb:hover{background:#4d4d4d}.canvas-editor{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px;margin-bottom:24px}.canvas-editor .section-title{font-size:18px;font-weight:600;color:var(--color-gray-900);margin-bottom:16px}.editor-tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:1px solid var(--color-gray-200);padding-bottom:0}.editor-tab{padding:10px 20px;font-size:14px;font-weight:500;color:var(--color-gray-600);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all .15s;margin-bottom:-1px}.editor-tab:hover{color:var(--color-gray-900)}.editor-tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.design-tab{display:flex;flex-direction:column;gap:16px}.editor-toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background-color:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--radius-md)}.add-element-btn{padding:8px 16px;font-size:13px;font-weight:500;color:#fff;background-color:var(--color-primary);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background-color .15s}.add-element-btn:hover{background-color:var(--color-primary-dark, #1d4ed8)}.toolbar-info{font-size:13px;color:var(--color-gray-500)}.editor-layout{display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:start}.canvas-wrapper{overflow:auto;background-color:var(--color-gray-100);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);padding:20px;background-image:linear-gradient(45deg,#e5e5e5 25%,transparent 25%),linear-gradient(-45deg,#e5e5e5 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#e5e5e5 75%),linear-gradient(-45deg,transparent 75%,#e5e5e5 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px;max-height:600px}.canvas-root{box-shadow:0 4px 12px #00000026;cursor:pointer;transition:outline .1s}.canvas-root--selected{outline:2px solid var(--color-primary);outline-offset:2px}.canvas-element{cursor:pointer;transition:outline .1s;box-sizing:border-box}.canvas-element:hover{outline:1px dashed rgba(37,99,235,.5)}.canvas-empty{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--color-gray-400);font-size:14px;text-align:center;pointer-events:none}.html-tab{min-height:400px}@media(max-width:1200px){.editor-layout{grid-template-columns:1fr;gap:16px}.canvas-wrapper{order:1;max-height:none}.element-tree{order:2;max-width:none;min-width:auto}.properties-panel{order:3}}.canvas-wrapper::-webkit-scrollbar{width:10px;height:10px}.canvas-wrapper::-webkit-scrollbar-track{background:var(--color-gray-200);border-radius:5px}.canvas-wrapper::-webkit-scrollbar-thumb{background:var(--color-gray-400);border-radius:5px}.canvas-wrapper::-webkit-scrollbar-thumb:hover{background:var(--color-gray-500)}.canvas-wrapper::-webkit-scrollbar-corner{background:var(--color-gray-200)}.preview-content{min-height:300px;max-height:70vh;overflow-y:auto}.preview-loading,.preview-error,.preview-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;text-align:center;gap:12px}.preview-loading p{color:var(--color-gray-600);font-size:14px}.preview-error{color:var(--color-danger)}.preview-error p{font-weight:500;margin-bottom:8px}.preview-error code{display:block;padding:12px;background-color:#fef2f2;border-radius:var(--radius-md);font-size:12px;max-width:100%;overflow-x:auto;text-align:left;color:#991b1b}.preview-image-container{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px}.preview-image{max-width:100%;height:auto;border-radius:var(--radius-md);box-shadow:var(--shadow-md)}.preview-info{font-size:13px;color:var(--color-gray-500)}.preview-empty{color:var(--color-gray-400);font-size:14px}.template-edit-page{max-width:1000px;margin:0 auto}.canvas-editor-wrapper{width:100vw;position:relative;left:50%;right:50%;margin-left:-50vw;margin-right:-50vw;padding:0 24px;box-sizing:border-box;margin-bottom:24px}.canvas-editor-wrapper .canvas-editor{max-width:none;margin:0}.template-edit-loading,.template-edit-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;gap:16px;background-color:#fff;border-radius:var(--radius-lg)}.template-edit-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;gap:16px}.header-left{display:flex;align-items:center;gap:16px;flex:1}.back-btn{padding:8px 12px;font-size:14px;font-weight:500;color:var(--color-gray-600);background:none;border:none;cursor:pointer;transition:color .2s}.back-btn:hover{color:var(--color-gray-900)}.template-name-input{flex:1;max-width:400px;padding:10px 14px;font-size:18px;font-weight:600;border:2px solid transparent;border-radius:var(--radius-md);background-color:transparent;transition:all .2s}.template-name-input:hover{background-color:var(--color-gray-50)}.template-name-input:focus{outline:none;border-color:var(--color-primary);background-color:#fff}.header-right{display:flex;gap:12px}.ttl-section{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px;margin-bottom:24px}.ttl-section .section-title{font-size:18px;font-weight:600;color:var(--color-gray-900);margin-bottom:16px}.ttl-input-group{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.ttl-label{font-size:14px;font-weight:500;color:var(--color-gray-700)}.ttl-input{width:120px;padding:8px 12px;font-size:14px;border:1px solid var(--color-gray-300);border-radius:var(--radius-md)}.ttl-input:focus{outline:none;border-color:var(--color-primary)}.ttl-unit{font-size:14px;color:var(--color-gray-600)}.ttl-hint{font-size:13px;color:var(--color-gray-500)}@media(max-width:640px){.template-edit-header,.header-left{flex-direction:column;align-items:stretch}.template-name-input{max-width:100%}.header-right{justify-content:flex-end}}.settings-page{max-width:800px}.settings-title{font-size:24px;font-weight:600;color:var(--color-gray-900);margin-bottom:24px}.settings-loading,.settings-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;gap:16px;background-color:#fff;border-radius:var(--radius-lg)}.settings-section{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px;margin-bottom:24px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.section-title{font-size:18px;font-weight:600;color:var(--color-gray-900);margin-bottom:8px}.section-description{font-size:14px;color:var(--color-gray-500);margin-bottom:20px}.setting-item{margin-bottom:20px}.setting-item:last-child{margin-bottom:0}.setting-label{display:block;font-size:14px;font-weight:500;color:var(--color-gray-700);margin-bottom:8px}.setting-input-group{display:flex;gap:8px}.setting-input{flex:1;padding:10px 12px;font-size:14px;border:1px solid var(--color-gray-300);border-radius:var(--radius-md)}.setting-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a}.setting-hint{font-size:13px;color:var(--color-gray-500);margin-top:6px}.fallback-asset{display:flex;align-items:center;gap:12px;padding:12px;background-color:var(--color-gray-50);border-radius:var(--radius-md)}.fallback-asset-name{font-weight:500;color:var(--color-gray-900)}.fallback-asset-size{color:var(--color-gray-500);font-size:13px}.upload-area{display:inline-block}.upload-input{display:none}.upload-label{display:inline-block;padding:10px 16px;font-size:14px;font-weight:500;color:var(--color-gray-700);background-color:#fff;border:1px dashed var(--color-gray-300);border-radius:var(--radius-md);cursor:pointer;transition:all .2s}.upload-label:hover{border-color:var(--color-primary);color:var(--color-primary)}.upload-btn{display:inline-block;padding:8px 14px;font-size:13px;font-weight:500;color:var(--color-primary);background-color:#2563eb1a;border-radius:var(--radius-md);cursor:pointer;transition:all .2s}.upload-btn:hover{background-color:#2563eb33}.assets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.asset-card{display:flex;justify-content:space-between;align-items:center;padding:12px;background-color:var(--color-gray-50);border-radius:var(--radius-md)}.asset-info{display:flex;flex-direction:column;gap:2px;min-width:0}.asset-name{font-size:14px;font-weight:500;color:var(--color-gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.asset-size{font-size:12px;color:var(--color-gray-500)}.asset-delete{width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--color-gray-400);background:none;border:none;border-radius:var(--radius-sm);transition:all .2s;flex-shrink:0;cursor:pointer}.asset-delete:hover{color:var(--color-danger);background-color:#fef2f2}.empty-message{font-size:14px;color:var(--color-gray-400);font-style:italic}@media(max-width:640px){.section-header{flex-direction:column;align-items:flex-start;gap:12px}.setting-input-group{flex-direction:column}.assets-grid{grid-template-columns:1fr}}*{margin:0;padding:0;box-sizing:border-box}:root{--color-primary: #2563eb;--color-primary-dark: #1d4ed8;--color-danger: #dc2626;--color-danger-dark: #b91c1c;--color-success: #16a34a;--color-warning: #d97706;--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--font-sans: system-ui, -apple-system, sans-serif;--font-mono: ui-monospace, monospace;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1)}body{font-family:var(--font-sans);background-color:var(--color-gray-50);color:var(--color-gray-900);line-height:1.5}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}
