*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-page: #181825;--bg-surface: #1e1e2e;--bg-canvas: #11111b;--bg-muted: #313244;--bg-muted-hover: #45475a;--bg-overlay: rgba(0, 0, 0, .6);--text-primary: #cdd6f4;--text-secondary: #a6adc8;--text-muted: #6c7086;--text-subtle: #585b70;--border-default: #313244;--border-strong: #45475a;--accent: #89b4fa;--accent-hover: #74c7ec;--accent-contrast: #1e1e2e;--success: #a6e3a1;--success-hover: #94e2d5;--success-soft: rgba(166, 227, 161, .15);--success-soft-border: rgba(166, 227, 161, .3);--danger: #f38ba8;--danger-soft: rgba(243, 139, 168, .1);--danger-soft-strong: rgba(243, 139, 168, .15);--danger-soft-border: rgba(243, 139, 168, .3);--shadow-card: 0 2px 16px rgba(0, 0, 0, .4);--shadow-dropdown: 0 4px 12px rgba(0, 0, 0, .3);--shadow-dialog: 0 8px 32px rgba(0, 0, 0, .5)}:root[data-theme=light]{--bg-page: #f4f6fb;--bg-surface: #ffffff;--bg-canvas: #e7edf7;--bg-muted: #e9edf5;--bg-muted-hover: #d7deea;--bg-overlay: rgba(15, 23, 42, .45);--text-primary: #1f2937;--text-secondary: #334155;--text-muted: #64748b;--text-subtle: #94a3b8;--border-default: #d8e0ed;--border-strong: #c2cedf;--accent: #2563eb;--accent-hover: #1d4ed8;--accent-contrast: #ffffff;--success: #16a34a;--success-hover: #15803d;--success-soft: rgba(22, 163, 74, .12);--success-soft-border: rgba(22, 163, 74, .25);--danger: #dc2626;--danger-soft: rgba(220, 38, 38, .08);--danger-soft-strong: rgba(220, 38, 38, .12);--danger-soft-border: rgba(220, 38, 38, .25);--shadow-card: 0 2px 16px rgba(15, 23, 42, .16);--shadow-dropdown: 0 4px 12px rgba(15, 23, 42, .14);--shadow-dialog: 0 8px 32px rgba(15, 23, 42, .2)}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:Inter,Roboto,system-ui,-apple-system,sans-serif;font-size:14px;line-height:1.5;color:var(--text-primary);background:var(--bg-page);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}input,select,button,textarea{font-family:inherit}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-subtle)}.template-list{min-height:100vh;background:var(--bg-page);color:var(--text-primary);padding:40px 24px;max-width:960px;margin:0 auto}.template-list__header{text-align:center;margin-bottom:32px}.template-list__title{font-size:32px;font-weight:700;color:var(--accent);margin:0 0 8px}.template-list__subtitle{font-size:14px;color:var(--text-muted);margin:0}.template-list__actions{display:flex;justify-content:center;align-items:center;gap:10px;margin-bottom:32px;flex-wrap:wrap}.template-list__empty{text-align:center;padding:60px 20px;color:var(--text-muted)}.template-list__hint{font-size:13px;margin-top:8px;max-width:400px;margin-left:auto;margin-right:auto}.template-list__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.template-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:8px;overflow:visible;position:relative;z-index:0;transition:border-color .15s}.template-card:hover{border-color:var(--border-strong)}.template-card--menu-open{z-index:3000}.template-card__preview{height:140px;background:var(--bg-canvas);display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden}.template-card__preview img{max-width:100%;max-height:100%;object-fit:contain}.template-card__no-preview{font-size:14px;color:var(--text-subtle)}.template-card__info{padding:12px}.template-card__name{font-weight:600;font-size:15px;margin-bottom:4px}.template-card__desc{font-size:12px;color:var(--text-muted);margin-bottom:4px}.template-card__meta{font-size:11px;color:var(--text-subtle)}.template-card__actions{padding:8px 12px 12px;display:flex;align-items:center;justify-content:space-between;gap:8px}.template-card__action-buttons{display:flex;align-items:center;gap:8px}.template-card__pdf-btn{width:30px;height:30px;border:1px solid var(--border-strong);border-radius:6px;background:transparent;color:var(--danger);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,color .15s,opacity .15s}.template-card__pdf-btn:hover:not(:disabled){background:var(--danger-soft)}.template-card__pdf-btn:disabled{opacity:.55;cursor:not-allowed}.btn{padding:8px 16px;border-radius:6px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s;font-family:inherit}.btn--primary{background:var(--accent);color:var(--accent-contrast)}.btn--primary:hover{background:var(--accent-hover)}.btn--small{padding:5px 10px;font-size:12px;border-radius:4px}.btn--outline{background:transparent;border:1px solid var(--border-strong);color:var(--text-primary)}.btn--outline:hover{background:var(--bg-muted)}.btn--danger{background:transparent;border:1px solid var(--border-strong);color:var(--danger)}.btn--danger:hover{background:var(--danger-soft)}.template-list__theme-btn{white-space:nowrap}.template-card__menu{position:relative}.template-card__menu--open{z-index:2000}.template-card__menu-btn{width:30px;height:30px;border:1px solid var(--border-strong);border-radius:6px;background:transparent;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer}.template-card__menu-btn:hover{background:var(--bg-muted);color:var(--text-primary)}.template-card__menu-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:150px;background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:8px;box-shadow:var(--shadow-dropdown);overflow:hidden;z-index:2100}.template-card__menu-item{width:100%;border:none;background:transparent;color:var(--text-primary);font-size:13px;text-align:left;padding:8px 10px;cursor:pointer}.template-card__menu-item:hover{background:var(--bg-muted)}.template-card__menu-item--danger{color:var(--danger)}.template-card__menu-item--danger:hover{background:var(--danger-soft)}.export-btn-wrapper{position:relative}.export-btn{padding:6px 14px;border-radius:4px;border:1px solid var(--border-strong);background:var(--accent);color:var(--accent-contrast);font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.export-btn:hover{background:var(--accent-hover)}.export-btn:disabled{opacity:.6;cursor:not-allowed}.export-dropdown{position:absolute;top:100%;right:0;margin-top:4px;background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:6px;overflow:hidden;z-index:100;min-width:160px;box-shadow:var(--shadow-dropdown)}.export-dropdown__item{display:block;width:100%;padding:8px 14px;border:none;background:none;color:var(--text-primary);font-size:13px;text-align:left;cursor:pointer;transition:background .15s}.export-dropdown__item:hover{background:var(--bg-muted)}.zoom-controls{display:flex;align-items:center;gap:2px;background:var(--bg-muted);border-radius:4px;padding:2px}.zoom-controls__btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-primary);border-radius:3px;cursor:pointer;font-size:14px;font-weight:600;padding:0;font-family:inherit}.zoom-controls__btn:hover{background:var(--bg-muted-hover)}.zoom-controls__btn:disabled{opacity:.3;cursor:not-allowed}.zoom-controls__btn--fit{width:auto;padding:0 6px;font-size:11px}.zoom-controls__value{font-size:12px;color:var(--text-secondary);min-width:38px;text-align:center;-webkit-user-select:none;user-select:none}.dialog-overlay{position:fixed;inset:0;background:var(--bg-overlay);display:flex;align-items:center;justify-content:center;z-index:1000}.dialog{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:12px;width:420px;max-width:90vw;box-shadow:var(--shadow-dialog)}.dialog__header{padding:16px 20px;font-size:16px;font-weight:600;border-bottom:1px solid var(--border-default)}.dialog__body{padding:20px;display:flex;flex-direction:column;gap:14px}.dialog__field{display:flex;flex-direction:column;gap:4px}.dialog__label{font-size:12px;color:var(--text-secondary);font-weight:500}.dialog__input,.dialog__textarea{padding:8px 10px;border-radius:6px;border:1px solid var(--border-strong);background:var(--bg-muted);color:var(--text-primary);font-size:14px;font-family:inherit;resize:vertical}.dialog__input:focus,.dialog__textarea:focus{outline:none;border-color:var(--accent)}.dialog__hint{font-size:12px;color:var(--text-muted);line-height:1.5}.dialog__footer{padding:12px 20px 16px;display:flex;justify-content:flex-end;gap:8px}.header{display:flex;align-items:flex-start;justify-content:space-between;min-height:76px;padding:8px 16px;background:var(--bg-surface);color:var(--text-primary);border-bottom:1px solid var(--border-default);flex-shrink:0}.header__left{display:flex;align-items:center;gap:10px;min-height:56px}.header__back{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--text-secondary);border-radius:4px;cursor:pointer}.header__back:hover{background:var(--bg-muted);color:var(--text-primary)}.header__logo{font-weight:700;font-size:18px;color:var(--accent)}.header__version{font-size:11px;font-weight:700;color:var(--accent);border:1px solid var(--border-strong);border-radius:999px;padding:1px 7px;line-height:1.3}.header__mode{font-size:12px;color:var(--text-muted);background:var(--bg-muted);padding:2px 8px;border-radius:4px}.header__center{display:flex;flex-direction:column;gap:6px;align-items:center;justify-content:center;min-height:56px}.header__right{display:flex;gap:8px;align-items:center;min-height:56px}.header__zoom-wrap{display:flex;align-items:center;justify-content:center}.header__btn{padding:6px 14px;border-radius:4px;border:none;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit}.header__btn--save{background:var(--success);color:var(--accent-contrast)}.header__btn--save:hover{background:var(--success-hover)}.header__theme-btn{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 10px;border:1px solid var(--border-strong);border-radius:6px;background:transparent;color:var(--text-primary);font-size:12px;font-weight:600;cursor:pointer;font-family:inherit}.header__theme-btn:hover{background:var(--bg-muted)}.toolbar{width:56px;min-width:56px;background:var(--bg-surface);border-right:1px solid var(--border-default);display:flex;flex-direction:column;align-items:center;padding:12px 0;gap:4px}.toolbar__btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-secondary);border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.toolbar__btn:hover{background:var(--bg-muted);color:var(--text-primary)}.toolbar__btn:active{background:var(--bg-muted-hover)}.canvas-editor{display:flex;flex-direction:column;align-items:center;gap:12px}.canvas-editor__wrapper{box-shadow:var(--shadow-card);border-radius:2px}.canvas-editor__info{font-size:12px;color:var(--text-muted)}.properties-panel{border-bottom:1px solid var(--border-default)}.properties-panel__header{padding:10px 16px;font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-default)}.properties-panel__empty{padding:16px;font-size:13px;color:var(--text-muted)}.properties-panel__content{padding:12px 16px;display:flex;flex-direction:column;gap:10px}.prop-group{display:flex;flex-direction:column;gap:4px}.prop-group--half{flex:1}.prop-row{display:flex;gap:8px;align-items:flex-end}.prop-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px}.prop-select,.prop-input{padding:6px 8px;border-radius:4px;border:1px solid var(--border-strong);background:var(--bg-muted);color:var(--text-primary);font-size:13px;width:100%;box-sizing:border-box}.prop-select:focus,.prop-input:focus{outline:none;border-color:var(--accent)}.prop-color{width:100%;height:32px;border:1px solid var(--border-strong);border-radius:4px;cursor:pointer;background:none;padding:2px}.prop-btn{padding:4px 10px;border:1px solid var(--border-strong);border-radius:4px;background:var(--bg-muted);color:var(--text-primary);font-size:14px;font-weight:700;cursor:pointer;transition:background .15s}.prop-btn:hover{background:var(--bg-muted-hover)}.prop-btn--active{background:var(--accent);color:var(--accent-contrast);border-color:var(--accent)}.prop-lock-row{display:flex;align-items:center;justify-content:space-between}.prop-lock-label{font-size:12px;color:var(--text-secondary);font-weight:500}.prop-lock-toggle{display:flex;align-items:center;gap:5px;padding:4px 10px;border-radius:4px;border:1px solid var(--border-strong);font-size:12px;font-family:inherit;cursor:pointer;transition:background .15s,border-color .15s}.prop-lock-toggle--unlocked{background:var(--success-soft);color:var(--success);border-color:var(--success-soft-border)}.prop-lock-toggle--unlocked:hover{background:var(--success-soft)}.prop-lock-toggle--locked{background:var(--danger-soft-strong);color:var(--danger);border-color:var(--danger-soft-border)}.prop-lock-toggle--locked:hover{background:var(--danger-soft-strong)}.prop-lock-hint{font-size:11px;color:var(--text-subtle);line-height:1.4}.prop-divider{height:1px;background:var(--border-default);margin:4px 0}.variables-panel{flex:1}.variables-panel__header{padding:10px 16px;font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-default)}.variables-panel__empty{padding:16px;font-size:13px;color:var(--text-muted);line-height:1.5}.variables-panel__content{padding:12px 16px;display:flex;flex-direction:column;gap:12px}.variable-field{display:flex;flex-direction:column;gap:4px}.variable-field__label{font-size:12px;color:var(--text-primary);display:flex;align-items:center;justify-content:space-between}.variable-field__type{font-size:10px;color:var(--text-muted);background:var(--bg-muted);padding:1px 6px;border-radius:3px}.variable-field__input{padding:6px 8px;border-radius:4px;border:1px solid var(--border-strong);background:var(--bg-muted);color:var(--text-primary);font-size:13px;width:100%;box-sizing:border-box}.variable-field__input:focus{outline:none;border-color:var(--accent)}.app-shell{display:flex;flex-direction:column;height:100vh;background:var(--bg-page);color:var(--text-primary)}.app-shell__body{display:flex;flex:1;overflow:hidden}.app-shell__canvas-area{flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg-canvas);overflow:auto;position:relative}.app-shell__sidebar{width:300px;min-width:300px;background:var(--bg-surface);border-left:1px solid var(--border-default);overflow-y:auto;display:flex;flex-direction:column}.fill-sidebar__header{padding:14px 16px;font-size:14px;font-weight:600;color:var(--text-secondary);border-bottom:1px solid var(--border-default)}.app-shell__sidebar-toggle{display:none;position:fixed;bottom:20px;right:20px;z-index:1000;width:56px;height:56px;border-radius:50%;background:var(--bg-surface);border:1px solid var(--border-default);color:var(--text-primary);cursor:pointer;box-shadow:0 4px 12px #00000026;transition:all .2s ease}.app-shell__sidebar-toggle:hover{transform:scale(1.05);box-shadow:0 6px 16px #0003}.app-shell__sidebar-toggle:active{transform:scale(.95)}@media(max-width:768px){.app-shell__sidebar{position:fixed;right:0;top:60px;bottom:0;z-index:999;transform:translate(100%);transition:transform .3s ease;box-shadow:-4px 0 12px #00000026}.app-shell__sidebar--open{transform:translate(0)}.app-shell__sidebar-toggle{display:flex;align-items:center;justify-content:center}.app-shell__canvas-area{margin-right:0}}
