@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700&display=swap";:root{color-scheme:light;--ink: #0f172a;--muted: #5b6b7c;--surface: #f5f8fc;--surface-strong: #ffffff;--sidebar: #f1f5fb;--accent: #2563eb;--accent-strong: #1d4ed8;--highlight: #e6f0ff;--border: rgba(15, 23, 42, .1);--shadow: 0 18px 40px rgba(15, 23, 42, .08)}*{box-sizing:border-box}[hidden]{display:none!important}html,body,#root{height:100%}body{margin:0;font-family:Manrope,Segoe UI,sans-serif;color:var(--ink);background:linear-gradient(120deg,#f8fafc,#eef3fb,#f3f6fb);min-height:100vh;overflow:hidden}.app-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh;height:100vh;position:relative;z-index:1;transition:grid-template-columns .3s ease}.sidebar{background:var(--sidebar);color:var(--ink);padding:28px 22px;display:flex;flex-direction:column;gap:32px;border-right:1px solid var(--border);transition:width .3s ease,padding .3s ease;height:100vh;position:sticky;top:0;overflow:auto}.sidebar .brand{display:flex;gap:16px;align-items:center;transition:gap .2s ease}.brand-text{overflow:hidden;max-width:220px;flex:1 1 auto;min-width:0;transition:max-width .25s ease,opacity .2s ease,flex-basis .25s ease;will-change:max-width,opacity,flex-basis}.brand-mark{width:48px;height:48px;border-radius:18px;background:transparent;display:grid;place-items:center;overflow:hidden}.brand-mark img{width:100%;height:100%;display:block}.sidebar-bottom{margin-top:auto;padding-top:14px;border-top:1px solid var(--border);display:grid;gap:8px}.sidebar-version{color:#6a7a8e;font-size:.78rem;font-weight:500;letter-spacing:.01em;text-transform:none;padding:2px 4px 0}.brand-name{font-size:1.1rem;font-weight:600;white-space:nowrap;transition:opacity .2s ease,transform .2s ease}.brand-meta{font-size:.8rem;color:var(--muted);white-space:nowrap;transition:opacity .2s ease,transform .2s ease}.nav{display:grid;gap:10px}.nav-item{border:1px solid transparent;border-radius:12px;padding:12px 14px;text-align:left;background:transparent;color:var(--muted);font:inherit;cursor:pointer;display:flex;align-items:center;gap:10px;transition:all .2s ease;text-decoration:none}.nav-icon{width:28px;height:28px;border-radius:10px;display:grid;place-items:center;background:#2563eb1f;color:var(--accent-strong);font-size:.85rem;font-weight:700}.nav-label{white-space:nowrap;transition:opacity .2s ease;will-change:opacity}.app-shell:not(.sidebar-collapsed) .brand-text{transition-delay:0s,.12s,0s}.app-shell:not(.sidebar-collapsed) .brand-name,.app-shell:not(.sidebar-collapsed) .brand-meta,.app-shell:not(.sidebar-collapsed) .nav-label{transition-delay:.12s}.nav-item.is-active{background:var(--highlight);color:var(--accent-strong);font-weight:600}.nav-item:not(:disabled):hover{background:#2563eb14;color:var(--accent-strong)}.nav-item:disabled{opacity:.55;cursor:not-allowed}.sidebar-footer{margin-top:auto}.pill{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;background:#2563eb1a;color:var(--accent-strong);font-size:.72rem;text-transform:uppercase;letter-spacing:.08em}.main-area{display:flex;flex-direction:column;height:100vh;overflow:auto}.topbar{background:var(--surface-strong);padding:24px 36px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);transition:padding .2s ease}.topbar.is-collapsed{padding:12px 36px}.topbar-left{display:flex;align-items:center;gap:18px}.page-title{font-size:1.6rem;font-weight:700}.page-subtitle{color:var(--muted);font-size:.9rem}.topbar-right{display:flex;align-items:center;gap:16px}.icon-button{width:42px;height:42px;border-radius:12px;border:1px solid var(--border);background:#fff;display:grid;gap:6px;place-content:center;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease}.icon-button:hover{border-color:#2563eb66;box-shadow:0 8px 16px #2563eb1f}.icon-line{width:18px;height:2px;background:var(--accent-strong)}.status,.ghost-button{display:none}.content{flex:1;padding:20px;display:flex;flex-direction:column;min-height:0}.settings-layout{display:grid;grid-template-columns:240px 1fr;gap:28px;align-items:start}.settings-menu{background:var(--surface-strong);border-radius:16px;border:1px solid rgba(15,23,42,.08);padding:18px;display:grid;gap:8px}.settings-title{font-size:.9rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin-bottom:8px}.settings-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;color:var(--muted);text-decoration:none;font-weight:600;border:0;background:transparent;width:100%;text-align:left;font:inherit;cursor:pointer;transition:background .2s ease,color .2s ease}.settings-item.is-active{background:var(--highlight);color:var(--accent-strong)}.settings-item:hover{background:#2563eb14;color:var(--accent-strong)}.settings-panels{display:grid;gap:24px}.settings-panel{display:none}.settings-panel.is-active{display:block}.panel{background:var(--surface-strong);padding:26px;border-radius:16px;box-shadow:var(--shadow);border:1px solid rgba(15,23,42,.06)}.panel-header{display:flex;justify-content:space-between;gap:20px;align-items:center;margin:-26px -26px 20px;padding:18px 22px;border-bottom:1px solid rgba(15,23,42,.08);background:#f8fafc}.panel-header h2{margin:0}.panel h2,.panel h3{margin:0 0 8px;font-weight:700}.panel p{margin:0;color:var(--muted)}.panel-tag{padding:6px 12px;border-radius:8px;background:var(--highlight);color:var(--accent-strong);font-size:.75rem;text-transform:uppercase;letter-spacing:.08em}.form-grid{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.field{display:grid;gap:8px;font-size:.9rem;color:var(--muted)}.field-help{font-size:.85rem;color:var(--muted);margin-top:-2px}.template-guidance-box{margin-bottom:12px;padding:10px 12px;border-radius:10px;border:1px solid #bfdbfe;background:#eff6ff;color:#1e3a8a;font-size:.9rem;line-height:1.4}.template-guidance-box code{color:#1e3a8a;font-weight:700}.field code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.9em;color:var(--ink);background:#0f172a0f;padding:2px 6px;border-radius:8px}.field input{padding:12px 14px;border-radius:12px;border:1px solid rgba(15,23,42,.12);font:inherit;background:#fff;transition:border-color .2s ease,box-shadow .2s ease}.field select{padding:12px 14px;border-radius:12px;border:1px solid rgba(15,23,42,.12);font:inherit;background:#fff;transition:border-color .2s ease,box-shadow .2s ease;appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%),linear-gradient(to right,transparent,transparent);background-position:calc(100% - 18px) 52%,calc(100% - 12px) 52%,0 0;background-size:6px 6px,6px 6px,100% 100%;background-repeat:no-repeat}.field input:focus{outline:none;border-color:#2563eb73;box-shadow:0 0 0 3px #2563eb1f}.field select:focus{outline:none;border-color:#2563eb73;box-shadow:0 0 0 3px #2563eb1f}.quick-select-buttons{display:flex;gap:6px;margin-top:8px}.quick-select-btn{padding:4px 8px;font-size:.7rem;font-weight:600;color:#64748b;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;transition:all .2s ease}.quick-select-btn:hover{background:#e2e8f0;border-color:#cbd5e1;color:#475569;transform:translateY(-1px)}.quick-select-btn:active{transform:translateY(0);background:#cbd5e1}.check{display:flex;align-items:center;gap:12px;padding:12px;border-radius:12px;border:1px solid rgba(15,23,42,.08);background:#2563eb0a;color:var(--ink);cursor:pointer;-webkit-user-select:none;user-select:none}.check input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent-strong);cursor:pointer}.builder-section{display:block;margin-top:4px}.builder-section-title{font-size:.85rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);font-weight:700;margin-top:6px}.builder-divider{height:1px;background:#0f172a14;margin:4px 0}.mode-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.mode-input{position:absolute;opacity:0;pointer-events:none}.mode-card{border-radius:14px;border:2px solid rgba(15,23,42,.12);background:#fff;padding:16px;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.mode-card-title{font-weight:800;color:var(--ink);font-size:1.05rem}.mode-card-subtitle{color:var(--muted);line-height:1.4}.mode-input:checked+.mode-card{border-color:#2563ebd9;box-shadow:0 0 0 4px #2563eb1f;background:#2563eb0a}#modeAppend:checked+.mode-card{border-color:#10b981e6;box-shadow:0 0 0 4px #10b98124;background:#10b98114}#modeTruncate:checked+.mode-card{border-color:#ef4444e6;box-shadow:0 0 0 4px #ef444424;background:#ef44440f}.builder-actions{display:flex;gap:10px}.secondary-button{padding:10px 16px;border-radius:10px;border:1px solid rgba(15,23,42,.14);background:#fff;color:var(--accent-strong);font-size:.9rem;font-weight:600;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.secondary-button:hover:not(:disabled){border-color:#2563eb73;box-shadow:0 10px 20px #0f172a14}.secondary-button:disabled{opacity:.55;cursor:not-allowed}.load-more-button{display:flex;flex-direction:column;gap:4px;padding:14px 20px}.load-more-main{font-size:1rem;font-weight:600;color:var(--ink)}.load-more-sub{font-size:.8rem;font-weight:400;color:var(--muted);opacity:.8}.tables-panel{border-radius:14px;border:2px solid rgba(15,23,42,.12);background:#fff;min-height:160px;flex:1;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;padding:14px;overflow:hidden}.tables-loading{display:grid;place-items:center;gap:10px;color:var(--muted);text-align:center;padding:18px 10px}.tables-error{color:#b0483a;font-weight:600;text-align:center}.tables-list{width:100%;flex:1;min-height:0;overflow:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:8px}.table-item{display:flex;align-items:center;justify-content:flex-start;gap:8px;padding:8px 12px;border-radius:9px;border:1px solid rgba(15,23,42,.1);background:#fff;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:.95rem}.table-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent-strong);flex:0 0 auto}.table-item span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ink);font-weight:500}.table-item:hover{background:#2563eb0d;border-color:#2563eb33}.spinner{width:44px;height:44px;border-radius:50%;border:5px solid rgba(37,99,235,.18);border-top-color:#2563ebe6;animation:spin .9s linear infinite}.builder-button-group{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:10px}.builder-layout .builder-button-group{grid-template-columns:1fr 1fr}.builder-primary{width:100%;margin-top:0}.builder-direct{margin-top:0}.combo{position:relative}.combo-input{width:100%;padding:12px 14px;border-radius:12px;border:1px solid rgba(15,23,42,.12);font:inherit;background:#fff;transition:border-color .2s ease,box-shadow .2s ease}.combo-input:focus{outline:none;border-color:#2563eb73;box-shadow:0 0 0 3px #2563eb1f}.combo-dropdown{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#fff;border:1px solid rgba(15,23,42,.12);border-radius:12px;box-shadow:0 18px 40px #0f172a1f;overflow:hidden;z-index:10}.combo-list{max-height:280px;overflow:auto;padding:8px}.combo-item{padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:16px;border-radius:8px;cursor:pointer;color:var(--ink);transition:all .15s ease;border:1px solid transparent}.combo-item:hover{background:#2563eb0d;border-color:#2563eb1a}.combo-item[aria-selected=true]{background:#2563eb1a;border-color:#2563eb33;box-shadow:0 0 0 1px #2563eb1a}.combo-item-name{font-weight:600;font-size:.9rem;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.4}.combo-item-meta{color:var(--muted);font-size:.8rem;font-weight:500;flex-shrink:0;opacity:.8;background:#2563eb0f;padding:4px 8px;border-radius:4px;min-width:40px;text-align:center}.combo-empty{padding:12px;color:var(--muted);font-size:.9rem}.builder-layout{display:grid;grid-template-columns:320px minmax(360px,1fr) minmax(360px,1fr);gap:16px;align-items:stretch;flex:1;min-height:0}.manage-list{margin-top:12px;display:flex;flex-direction:column;gap:8px;overflow:auto;min-height:0;padding-right:6px}.manage-empty{margin-top:12px;color:var(--muted);text-align:center}.manage-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:9px;border:1px solid rgba(15,23,42,.1);background:#fff;cursor:pointer;-webkit-user-select:none;user-select:none;font-weight:500;color:var(--ink);font-size:.95rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.manage-item:before{content:none}.manage-item:hover{background:#2563eb0d;border-color:#2563eb33}.manage-item.is-active{background:var(--highlight);border-color:#2563eb66;color:var(--accent-strong);box-shadow:0 0 0 1px #2563eb1a}.manage-item.is-active:before{content:none}.manage-editor{flex:1;min-height:0}.manage-hint{margin-top:10px;color:var(--muted);font-size:.9rem}.builder-panel{display:flex;flex-direction:column;justify-content:flex-start;min-height:0;overflow:hidden}.builder-form{display:flex;flex-direction:column;gap:16px;flex:1;height:100%;min-height:0;overflow:auto;padding-right:6px}.builder-span-2{grid-column:1 / -1}.builder-textarea{flex:1;display:flex;flex-direction:column}.builder-panel .builder-textarea{min-height:0}textarea.code-area{flex:1;width:100%;height:100%;min-height:0;resize:none;border:1px solid var(--border);border-radius:8px;padding:16px;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:.9rem;line-height:1.6;background:#fff;color:var(--ink);transition:border-color .2s ease,box-shadow .2s ease}textarea.code-area:focus{outline:none;border-color:#2563eb73;box-shadow:0 0 0 3px #2563eb1f}textarea.code-area.is-terminal{background:radial-gradient(circle at 0 0,rgba(37,99,235,.14),transparent 40%),#0b1220;color:#d1fae5;border-color:#94a3b82e;box-shadow:inset 0 0 0 1px #ffffff08}textarea.code-area.is-terminal::placeholder{color:#d1fae58c}.builder-panel .form-grid,.builder-panel .builder-textarea,.builder-panel .preview-surface{margin-top:12px}.preview-surface{flex:1;border-radius:12px;border:1px solid rgba(15,23,42,.12);background:#fff;padding:14px;overflow:auto;min-height:0;display:flex}.preview-frame{width:100%;height:100%;border:0;background:#fff;border-radius:10px}.preview-placeholder{color:var(--muted);font-size:.9rem;line-height:1.6}.action-panel{display:flex;justify-content:space-between;align-items:center;gap:20px}.action-row{display:flex;align-items:center;gap:16px}.save-row{justify-content:flex-end;padding-top:4px}.save-status{color:var(--muted);font-size:.85rem}.save-status[data-tone='"success"']{color:#2563eb}.save-status[data-tone='"error"']{color:#b0432f}.primary-button{padding:10px 16px;border-radius:10px;border:1px solid transparent;background:var(--accent-strong);color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #2563eb33;transition:transform .2s ease,box-shadow .2s ease}.primary-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 16px 30px #2563eb38}.primary-button:disabled{opacity:.55;cursor:not-allowed}.sidebar-collapsed{grid-template-columns:96px 1fr}.sidebar-collapsed .sidebar{padding:24px 16px}.sidebar-collapsed .brand{justify-content:center;gap:0}.sidebar-collapsed .brand-mark{margin:0 auto}.sidebar-collapsed .brand-text{max-width:0;opacity:0;flex:0 0 0;pointer-events:none;transition-delay:0s,0s,0s}.sidebar-collapsed .brand-name,.sidebar-collapsed .brand-meta,.sidebar-collapsed .nav-label{opacity:0;pointer-events:none;transition-delay:0s}.sidebar-collapsed .nav-label{max-width:0;overflow:hidden}.sidebar-collapsed .nav-item{padding:12px;justify-content:center}.sidebar-collapsed .sidebar-footer{display:none}@media(max-width:980px){.app-shell{grid-template-columns:1fr;height:auto}.settings-layout{grid-template-columns:1fr}.content{padding:24px 24px 0;overflow-x:auto}.builder-layout{min-width:1260px;flex:none;height:auto}.manage-layout{min-width:1240px;flex:none;height:auto}.mode-grid{grid-template-columns:1fr}.sidebar{position:fixed;inset:0 auto 0 0;width:260px;transform:translate(-110%);transition:transform .3s ease;z-index:5;height:100vh}.sidebar.is-open{transform:translate(0)}.topbar{padding:20px 24px}.action-panel{flex-direction:column;align-items:flex-start}}@media(max-width:640px){.topbar-right{display:none}.panel{padding:20px}.page-title{font-size:1.3rem}}.insertion-overlay{position:fixed;inset:0;background:#0f172ad9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000}.insertion-spinner-container{background:#fff;border-radius:16px;padding:48px 64px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;align-items:center;gap:24px}.insertion-spinner{width:64px;height:64px;border:6px solid #e5e7eb;border-top-color:#2563eb;border-radius:50%;animation:spin .8s linear infinite}.insertion-text{font-size:18px;font-weight:600;color:#0f172a;text-align:center;min-width:200px}.modal-overlay{position:fixed;inset:0;background:#0f172ab3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:10px;animation:fadeIn .2s ease}.modal-box{background:var(--surface-strong);border-radius:16px;box-shadow:0 24px 60px #0f172a33;width:100%;max-width:440px;overflow:hidden;animation:slideUp .2s ease}.modal-box .modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid rgba(15,23,42,.08)}.modal-box .modal-header h3{margin:0;font-size:16px;font-weight:700;color:var(--text-primary)}.modal-box .modal-body{display:block;padding:18px 20px;font-size:14px;color:var(--text-secondary);line-height:1.6}.modal-box .modal-body p{margin:0 0 8px}.modal-box .modal-body p:last-child{margin:0}.modal-box .modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:14px 20px;border-top:1px solid rgba(15,23,42,.08);background:linear-gradient(to bottom,#fff,#f8fafc)}.modal-box .modal-footer .secondary-button:first-child{margin-right:auto}.modal-container{background:var(--surface-strong);border-radius:16px;box-shadow:0 24px 60px #0f172a33;max-width:1200px;width:100%;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s ease}.modal-container-large{max-width:98vw;width:98vw;max-height:96vh;height:96vh;border-radius:18px;overflow:hidden;border:1px solid rgba(15,23,42,.12)}.template-modal-container{max-width:1480px;width:min(1480px,96vw);height:90vh;max-height:90vh}.template-modal-container .modal-header{padding:20px 24px;background:linear-gradient(to bottom,#f8fafc,#fff);border-bottom:1px solid rgba(15,23,42,.08)}.template-modal-container .modal-header h2{margin:0;font-size:1.1rem;letter-spacing:-.02em}.template-modal-container .modal-close{width:40px;height:40px;border-radius:12px;border:1px solid rgba(15,23,42,.1);background:#fffc;font-size:1.25rem}.template-modal-container .modal-close:hover{background:#0f172a0a;border-color:#2563eb59;color:var(--accent-strong)}.modal-header{padding:18px 24px;background:linear-gradient(to bottom,#fafafa,#fff);border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between;gap:24px}.modal-header-left{flex:1;min-width:0}.modal-header h2{margin:0 0 8px;font-size:1.25rem;font-weight:700;color:#0f172a;letter-spacing:-.02em}.modal-info{display:flex;align-items:center;gap:24px;flex-wrap:wrap}.modal-info-item{display:flex;align-items:center;gap:8px;font-size:.875rem;padding:8px 14px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;transition:all .2s ease}.modal-info-item:hover{border-color:#d1d5db;box-shadow:0 2px 4px #0000000d}.modal-info-item strong{color:#64748b;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.modal-info-item span{color:#2563eb;font-weight:600}.modal-mode-select{padding:8px 14px;border-radius:8px;border:2px solid;font-size:.875rem;font-weight:700;cursor:pointer;transition:all .2s ease;min-width:140px}.modal-mode-select[value=append]{background:linear-gradient(135deg,#22c55e14,#22c55e1f);border-color:#22c55e80;color:#15803d}.modal-mode-select[value=append]:hover{background:linear-gradient(135deg,#22c55e26,#22c55e33);border-color:#22c55eb3;box-shadow:0 2px 8px #22c55e33}.modal-mode-select[value=append]:focus{outline:none;border-color:#22c55ecc;box-shadow:0 0 0 4px #22c55e26}.modal-mode-select[value=truncate]{background:linear-gradient(135deg,#ef444414,#ef44441f);border-color:#ef444480;color:#b91c1c}.modal-mode-select[value=truncate]:hover{background:linear-gradient(135deg,#ef444426,#ef444433);border-color:#ef4444b3;box-shadow:0 2px 8px #ef444433}.modal-mode-select[value=truncate]:focus{outline:none;border-color:#ef4444cc;box-shadow:0 0 0 4px #ef444426}.modal-header-actions{display:flex;align-items:center;gap:8px}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--muted);cursor:pointer;width:36px;height:36px;border-radius:8px;display:grid;place-items:center;transition:all .2s ease}.modal-close:hover{background:var(--surface);color:var(--ink)}.modal-body{display:grid;grid-template-columns:300px 1fr;flex:1;overflow:hidden;border-bottom:1px solid var(--border)}.template-modal-columns{min-height:0;height:100%;border-radius:16px;border:1px solid rgba(15,23,42,.1);overflow:hidden;background:var(--surface);box-shadow:0 18px 40px #0f172a14;display:flex;align-items:stretch;gap:0;flex:1}.template-modal-columns>.modal-code,.template-modal-columns>.modal-preview{min-width:0;flex:1 1 0;min-height:0}.template-modal-body{grid-template-columns:1fr;grid-template-rows:auto 1fr;padding:18px 18px 16px;gap:14px;background:var(--surface-strong);min-height:0}.template-modal-header{display:grid;grid-template-columns:1fr;align-items:center;gap:10px}.template-modal-header .form-group{margin-bottom:0}.template-modal-hint{padding:8px 10px;border-radius:8px;background:linear-gradient(135deg,#2563eb14,#3b82f624);border:1px solid rgba(37,99,235,.2);color:#1f3a8a;font-size:.78rem;line-height:1.3}.modal-body-two-column{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);gap:20px}.modal-body-three-column{grid-template-columns:420px minmax(0,1fr);background:#f8fafc}.modal-sidebar{border-right:1px solid #dbe4ef;display:flex;flex-direction:column;background:#fff;overflow:hidden;min-height:0}.modal-sidebar-header{padding:12px 14px;font-weight:600;font-size:.82rem;color:var(--ink);border-bottom:1px solid #e4ebf4;background:#f8fafc;display:flex;align-items:center;justify-content:space-between;gap:10px;flex-shrink:0}.modal-sidebar-header .modal-header-btn,.modal-code-header .modal-header-btn{padding:6px 10px;font-size:.76rem;border-radius:8px}.template-list{flex:1;overflow-y:auto;padding:10px;min-height:0}.template-list-item{display:flex;align-items:center;justify-content:space-between;padding:6px 9px;cursor:pointer;transition:background-color .15s ease,border-color .15s ease;border-radius:8px;margin-bottom:4px;gap:6px;border:1px solid #e2eaf3;background:#fff}.template-list-item:hover{background:#f4f8ff;border-color:#c8d9f0}.template-list-item.is-active{background:#edf4ff;color:#1e3a8a;border-color:#9cb8e2}.template-list-item.is-active .template-item-name{color:#1e3a8a;font-weight:600}.template-list-item.is-active .delete-template{color:#1e3a8a;background:#3b82f626}.template-list-item.is-active .delete-template:hover{background:#3b82f638}.template-list-item.is-invalid{background:#fee;border-color:#fcc}.template-list-item.is-invalid:hover{background:#fdd;border-color:#faa}.template-list-item.is-invalid.is-active{background:#dc3545;border-color:#dc3545}.template-list-item.is-invalid .template-item-index{color:#dc3545;font-weight:700}.template-list-item.is-invalid.is-active .template-item-index{color:#ffffffe6}.template-item-info{flex:1;min-width:0;display:flex;align-items:center;gap:7px}.template-item-index{font-size:.7rem;font-weight:400;color:var(--muted);min-width:20px}.template-list-item.is-active .template-item-index{color:#4b6fa7}.template-item-name{font-size:.8rem;font-weight:400;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.delete-template{background:none;border:none;color:#ef4444;font-size:.74rem;cursor:pointer;width:24px;height:24px;border-radius:6px;display:grid;place-items:center;transition:all .15s ease;flex-shrink:0;margin-left:6px}.delete-template:hover{background:#ef44441a}.modal-main-two-column{display:grid;grid-template-columns:minmax(320px,.7fr) minmax(640px,1.3fr);min-height:0}.modal-body-three-column .modal-code{border-right:1px solid #dbe4ef;display:flex;flex-direction:column;background:#fff;min-width:0;min-height:0}.template-modal-columns .modal-code{background:#0f172a;order:1}.modal-code-header{padding:12px 14px;font-weight:600;font-size:.8rem;color:#334155;border-bottom:1px solid #e4ebf4;background:#f8fafc;display:flex;align-items:center;justify-content:space-between;gap:10px}.template-modal-columns .modal-code-header{background:#111827;color:#e2e8f0;border-bottom:1px solid rgba(148,163,184,.2)}.modal-preview{display:flex;flex-direction:column;background:#fff;min-width:0;min-height:0}.template-modal-columns .modal-preview{order:2}.modal-preview-header{padding:12px 14px;font-weight:600;font-size:.8rem;color:var(--ink);border-bottom:1px solid #e4ebf4;background:#f8fafc}.preview-tabs{display:flex;gap:4px}.preview-tab{background:none;border:none;padding:8px 16px;font-size:.85rem;font-weight:500;color:var(--muted);cursor:pointer;border-radius:6px;transition:all .15s ease}.preview-tab:hover{background:var(--surface);color:var(--ink)}.preview-tab.is-active{background:var(--accent);color:#fff}.preview-frame-container{flex:1;overflow:auto;background:#f3f7fc}.template-modal-columns .preview-frame-container{padding:12px;background:linear-gradient(180deg,#94a3b824,#94a3b80f)}.code-view-container{flex:1;overflow:auto;background:var(--surface)}.modal-body-three-column .code-view-container{background:#fff}.template-modal-columns .code-view-container{background:#0b1220}.code-view{width:100%;height:100%;min-height:100%;font-family:Courier New,monospace;font-size:.85rem;line-height:1.5;resize:none}.modal-body-three-column .code-view{background:#fff;color:#0f172a;border:none;padding:18px;font-size:.82rem;line-height:1.45}.modal-body-three-column .code-view::placeholder{color:#8a94a5}.modal-body-three-column .code-view:focus{outline:none;border:none;box-shadow:none}.template-modal-columns .code-view{background:transparent;color:#e2e8f0;border:none;padding:20px}.template-modal-columns .code-view::placeholder{color:#e2e8f080}.modal-preview-frame{width:100%;height:100%;border:1px solid #d6e0ec;border-radius:10px;background:#fff;min-height:100%}.template-modal-columns .modal-preview-frame{border:1px solid rgba(15,23,42,.12);border-radius:12px;overflow:hidden}.modal-footer{padding:14px 18px;display:flex;align-items:center;justify-content:space-between;gap:12px;background:linear-gradient(to bottom,#fff,#f8fafc);border-top:1px solid rgba(15,23,42,.08)}.modal-insert-actions{display:flex;gap:12px}.append-button{padding:10px 16px;border-radius:10px;border:1px solid transparent;background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-weight:600;font-size:.9rem;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 4px 12px #10b98140}.append-button:hover{transform:translateY(-1px);box-shadow:0 8px 20px #10b98159}.append-button:active{transform:translateY(0)}.append-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.truncate-button{padding:10px 16px;border-radius:10px;border:1px solid rgba(220,38,38,.3);background:#fff;color:#dc2626;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease}.truncate-button:hover{background:#dc26260d;border-color:#dc262680}.truncate-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.truncate-button:active{transform:translateY(0)}.danger-button{padding:10px 16px;border-radius:10px;border:1px solid rgba(220,38,38,.3);background:#fff;color:#dc2626;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease}.danger-button:hover:not(:disabled){background:#dc26260d;border-color:#dc262680}.danger-button:active{transform:none}.danger-button:disabled{opacity:.55;cursor:not-allowed}.button-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;margin-left:8px}@keyframes spin{to{transform:rotate(360deg)}}#generateButton{display:flex;align-items:center;justify-content:center;gap:8px}#generateButton:disabled{opacity:.6;cursor:not-allowed}@media(max-width:1400px){.modal-body-three-column{grid-template-columns:360px minmax(0,1fr)}}.panel-actions{display:flex;gap:8px;align-items:center}.templates-manager-layout{display:grid;grid-template-columns:320px minmax(0,1fr);gap:16px;align-items:stretch;flex:1;min-height:0;width:100%;margin:0}@media(max-width:1200px){.templates-manager-layout{grid-template-columns:270px minmax(0,1fr);gap:12px}}@media(max-width:1100px){.templates-manager-layout{grid-template-columns:260px minmax(360px,1fr)}}@media(max-width:980px){.templates-manager-layout{grid-template-columns:1fr;flex:none;height:auto}.templates-manager-layout .panel,.templates-manager-layout .preview-frame{min-height:320px}}@media(max-width:560px){.templates-manager-layout{gap:14px}.panel-actions{flex-wrap:wrap;justify-content:flex-start}}.templates-manager-layout .panel{display:flex;flex-direction:column;overflow:hidden;min-height:0;padding:16px;border-radius:12px;border:1px solid #dce3ec;box-shadow:none;background:#fff}.templates-manager-layout .panel-content{flex:1;overflow:hidden;display:flex;flex-direction:column;min-height:0}.templates-manager-layout .panel-content,.templates-manager-layout .preview-surface{margin-top:10px}.templates-manager-layout .panel-header{margin:0 0 8px;padding:0 0 10px;gap:10px;border-bottom:1px solid #e7edf4;background:transparent}.templates-manager-layout .panel-header h2{font-size:.98rem;font-weight:600;letter-spacing:.01em;color:#1f2937}.templates-manager-layout .panel-actions .primary-button,.templates-manager-layout .panel-actions .secondary-button,.templates-manager-layout .panel-actions .danger-button{padding:7px 11px;font-size:.78rem;border-radius:8px}.templates-manager-layout .manage-filter input{padding:8px 10px;font-size:.83rem;border-radius:10px}.template-editor-panel .panel-content{gap:12px}.template-editor-tabs{margin-top:0;padding:0;border:none;background:transparent}.template-editor-surface{flex:1;min-height:0;overflow:hidden;border:1px solid #e5ebf2;border-radius:12px;background:#f8fafc}.template-editor-surface .preview-surface{margin-top:0;height:100%;border:none;border-radius:0;padding:0;background:transparent;overflow:hidden}.template-editor-surface .preview-frame{width:100%;height:100%;display:block;border:none;border-radius:0;background:transparent}.template-editor-surface .code-area{height:100%;min-height:100%;border:none;border-radius:0}.template-code-tab{height:100%;min-height:0;display:flex;flex-direction:column;gap:10px;padding:10px}.template-code-tab .code-area{flex:1;min-height:0}.templates-list-panel .panel-header h2{margin-bottom:0}.templates-list-panel .panel-header .secondary-button{padding:8px 12px;border-radius:10px}.templates-list-panel .manage-filter{padding:0 0 10px}.templates-list-panel .manage-filter input{width:100%;height:38px;padding:0 12px;border-radius:10px;border:1px solid #d5deea;background:#fff}.templates-list-panel .manage-filter input::placeholder{color:#7b8798}.templates-list-panel .manage-filter input:focus{border-color:#9fb7dd;box-shadow:0 0 0 3px #2563eb1a}.manage-layout{display:grid;grid-template-columns:220px 280px minmax(700px,1fr);gap:16px;align-items:stretch;flex:1;min-height:0}.builder-layout .panel,.manage-layout .panel{display:flex;flex-direction:column;overflow:hidden;min-height:0;padding:16px;border-radius:12px;border:1px solid #dce3ec;box-shadow:none;background:#fff}.builder-layout .panel-content,.manage-layout .panel-content{flex:1;overflow:hidden;display:flex;flex-direction:column;min-height:0}.builder-layout .panel-content,.builder-layout .preview-surface,.builder-layout .manage-editor,.manage-layout .panel-content,.manage-layout .preview-surface,.manage-layout .manage-editor{margin-top:10px}.builder-layout .panel-header,.manage-layout .panel-header{margin:0 0 8px;padding:0 0 10px;gap:10px;border-bottom:1px solid #e7edf4;background:transparent}.builder-layout .panel-header h2,.manage-layout .panel-header h2{font-size:.98rem;font-weight:600;letter-spacing:.01em;color:#1f2937}.builder-layout .panel-tag,.manage-layout .panel-tag{font-size:.68rem;padding:4px 8px;border-radius:999px}.builder-layout .secondary-button,.builder-layout .primary-button,.builder-layout .danger-button,.manage-layout .secondary-button,.manage-layout .primary-button,.manage-layout .danger-button{padding:7px 11px;font-size:.78rem;border-radius:8px}.manage-toolbar{display:flex;gap:8px}.manage-list-panel{padding:0}.manage-list-panel .panel-header{margin:0 0 8px}.manage-generate-prompt{display:flex;flex-direction:column;align-items:center;gap:16px;padding:40px 20px;text-align:center;color:var(--muted)}.manage-filter{padding:0 0 10px}.manage-filter input{width:100%;height:38px;padding:0 12px;border-radius:10px;border:1px solid #d5deea;font:inherit;font-size:.83rem;background:#fff;transition:border-color .2s ease,box-shadow .2s ease}.manage-filter input:focus{outline:none;border-color:#9fb7dd;box-shadow:0 0 0 3px #2563eb1a}.manage-items{padding:0;overflow-y:auto;flex:1;min-height:0;display:flex;flex-direction:column;gap:8px}.manage-subtitle{margin:6px 0 0;color:var(--muted);font-size:.8rem}.template-items{padding:0;overflow-y:auto;flex:1;min-height:0;display:flex;flex-direction:column;gap:8px}.loading-state,.error-state,.empty-state{padding:40px 20px;text-align:center;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:12px}.error-state{color:#ef4444}.templates-list-panel{padding:0}.templates-list-panel .panel-header{margin:0 0 20px}.template-item{padding:7px 10px;border-radius:8px;cursor:pointer;transition:all .15s ease;border:1px solid #e4eaf2;margin-bottom:0;display:flex;justify-content:space-between;align-items:center;background:#fff}@media(max-width:1200px){.template-item{padding:8px 12px;margin-bottom:0}.template-item-name{font-size:.95rem}.template-item-id{font-size:.8rem;padding:4px 8px}}.template-item:hover{background:#f4f8ff;border-color:#cfdcf2}.template-item.is-active{background:#edf4ff;border-color:#b5c8ea;box-shadow:inset 0 0 0 1px #d1e0f7}.template-item-name{font-weight:500;font-size:.84rem;color:var(--ink)}.template-item-id{font-size:.74rem;color:var(--muted);background:#eef3fb;padding:3px 7px;border-radius:4px}.template-editor-panel .template-name-field label{font-size:.82rem;font-weight:600;color:#4b5563}.template-editor-panel .template-name-field .form-input{font-size:.9rem;padding:9px 11px;border-radius:10px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:var(--ink)}.form-input{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:8px;font-size:.95rem;font-family:inherit;transition:border-color .2s ease,box-shadow .2s ease}.form-input:focus{outline:none;border-color:#2563eb80;box-shadow:0 0 0 3px #2563eb1a}.template-name-field{margin-bottom:16px;flex-shrink:0}.template-name-field label{display:block;margin-bottom:6px;font-weight:600;font-size:.85rem;color:var(--ink)}.login-page{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(900px 500px at 50% -120px,#2563eb1f,#2563eb00 62%),linear-gradient(180deg,#eef2f7,#e9eef5)}.login-shell{width:min(560px,100%)}.login-card{background:#fff;border:1px solid #d7deea;border-radius:16px;box-shadow:0 16px 34px #0f172a1a;padding:34px;display:grid;gap:20px}.login-brand{display:flex;align-items:center;gap:12px;padding-bottom:14px;border-bottom:1px solid #e6ecf5}.login-brand-text{display:grid;gap:2px}.login-brand-title{margin:0;color:#0f172a;font-size:1.35rem;font-weight:700;line-height:1.2}.login-form-header h2{margin:0;font-size:2.2rem;color:#0f172a;line-height:1.12}.login-form-header p{margin:8px 0 0;color:#5e728d;font-size:.96rem}.login-form{display:grid;gap:14px}.login-field{display:grid;gap:7px;font-size:.82rem;color:#334155;font-weight:600;letter-spacing:.03em;text-transform:uppercase}.login-input{width:100%;padding:14px 15px;border:1px solid #c9d4e8;border-radius:12px;background:#fff;color:#0f172a;font-size:1.06rem;box-shadow:none;transition:border-color .2s ease,box-shadow .2s ease,background-color .2s ease,transform .12s ease}.login-input::placeholder{color:#8ea2be}.login-input:focus{outline:none;border-color:#2563eb;background:#fff;box-shadow:0 0 0 3px #2563eb24;transform:none}.login-error{margin:0;color:#b91c1c;font-size:.84rem;font-weight:600;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;padding:9px 11px}.login-submit{margin-top:6px;width:100%;border:0;border-radius:12px;padding:14px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;font-size:1.08rem;font-weight:700;letter-spacing:.01em;cursor:pointer;transition:transform .12s ease,box-shadow .2s ease,opacity .2s ease;box-shadow:0 8px 18px #2563eb47}.login-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 12px 22px #1d4ed852}.login-submit:disabled{opacity:.72;cursor:not-allowed}.login-brand-meta{color:#64748b;font-size:.82rem;font-weight:500}.sidebar-logout{width:100%;margin-top:2px;border:1px solid rgba(15,23,42,.14);background:#fff;color:#334155;border-radius:10px;padding:10px 12px;font-size:.92rem;font-weight:600;cursor:pointer;transition:border-color .2s ease,color .2s ease,background .2s ease}.sidebar-logout:hover{border-color:#dc262659;background:#fff7f7;color:#b91c1c}.sidebar-logout:active{background:#fee2e2}@media(max-width:980px){.modal-container-large{max-width:98vw}.login-shell{width:min(480px,100%)}.login-page{padding:16px}.login-card{padding:26px}.login-form-header h2{font-size:1.85rem}.modal-body-three-column{grid-template-columns:1fr}.modal-sidebar{border-right:none;border-bottom:1px solid var(--border);max-height:200px}.modal-main-two-column{grid-template-columns:1fr}.modal-body-three-column .modal-code{border-right:none;border-bottom:1px solid #dbe4ef;min-height:320px}}.toast-container{position:fixed;top:24px;right:24px;z-index:10000;display:flex;flex-direction:column;gap:12px;pointer-events:none}.toast{background:#fff;border-radius:12px;padding:16px 20px;box-shadow:0 10px 30px #0000001f,0 4px 8px #0000000d;display:flex;align-items:center;gap:12px;min-width:300px;max-width:400px;pointer-events:auto;animation:toastSlideIn .3s cubic-bezier(.16,1,.3,1);border-left:4px solid transparent;transform-origin:right center}.toast.toast-success{border-left-color:#10b981}.toast.toast-error{border-left-color:#ef4444}.toast-icon{font-size:1.2rem;flex-shrink:0}.toast-content{flex:1}.toast-title{font-weight:700;font-size:.9rem;color:var(--ink);margin-bottom:2px}.toast-message{font-size:.85rem;color:var(--muted);line-height:1.4}@keyframes toastSlideIn{0%{opacity:0;transform:translate(100%) scale(.9)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes toastSlideOut{to{opacity:0;transform:translate(100%) scale(.9)}}.delete-modal{padding:0;overflow:hidden;border:1px solid #fee2e2}.delete-header{background:#fef2f2;border-bottom:1px solid #fee2e2;padding:20px;display:flex;align-items:center;justify-content:center;gap:10px;color:#b91c1c}.delete-header-icon{font-size:1.2rem}.delete-header-text{font-weight:800;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}.delete-modal .notification-content{padding:32px 32px 12px}.delete-modal .notification-actions{padding:0 32px 32px}.delete-warning-text{color:#dc2626!important;font-weight:600;background:#fef2f2;padding:12px;border-radius:8px;font-size:.9rem!important;border:1px solid #fee2e2}.notification-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:grid;place-items:center;z-index:10000;animation:fadeIn .2s ease}.notification-modal{background:#fff;border-radius:16px;box-shadow:0 24px 48px #0003;max-width:440px;width:90%;padding:32px;text-align:center;animation:slideUp .3s ease}.notification-icon{font-size:3rem;margin-bottom:16px;animation:bounce .5s ease}.notification-content h3{margin:0 0 12px;font-size:1.25rem;font-weight:600;color:var(--ink)}.notification-content p{margin:0 0 24px;font-size:.95rem;color:var(--muted);line-height:1.6}.notification-actions{display:flex;justify-content:center;gap:12px}.notification-actions button{min-width:100px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes bounce{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}
