:root{--orange:#E8521A;--orange-h:#c9440f;--orange-l:#fff3ef;--blue:#1E3A5F;--sky:#eaf4fd;--white:#fff;--gray-bg:#f5f7fa;--gray-1:#e6eaf0;--gray-2:#c4cdd8;--gray-3:#8896ab;--text:#1a2433;--text-s:#4a5568;--r:10px;--font:'Nunito Sans',sans-serif;--font-h:'Nunito',sans-serif;--shadow:0 1px 4px rgba(30,58,95,.08),0 4px 16px rgba(30,58,95,.07)}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font);background:var(--gray-bg);color:var(--text);min-height:100vh;display:flex;flex-direction:column}
header{background:var(--white);border-bottom:1px solid var(--gray-1);padding:0 32px;height:60px;display:flex;align-items:center;gap:14px;box-shadow:0 2px 8px rgba(30,58,95,.06);position:sticky;top:0;z-index:50}
.logo{display:flex;align-items:center;text-decoration:none}
.hd{width:1px;height:22px;background:var(--gray-1)}
.header-tool{font-size:12px;font-weight:700;color:var(--gray-3)}
.header-stats{margin-left:auto;display:flex;gap:8px;align-items:center}
.stat-chip{display:flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;background:var(--gray-bg);border:1px solid var(--gray-1);font-size:11px;font-weight:600;color:var(--gray-3);white-space:nowrap}
.stat-chip .v{color:var(--blue);font-weight:800}
.stat-chip.save .v{color:var(--orange)}
.tabs-wrap{background:var(--white);border-bottom:2px solid var(--gray-1);padding:0 32px;display:flex;align-items:center;gap:2px}
.tab{padding:13px 20px;font-family:var(--font-h);font-size:13px;font-weight:700;cursor:pointer;border:none;background:none;color:var(--gray-3);border-bottom:3px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s;display:flex;align-items:center;gap:7px}
.tab:hover{color:var(--text-s)}
.tab.active{color:var(--orange);border-bottom-color:var(--orange)}
.tab-badge{padding:1px 6px;border-radius:3px;font-size:10px;font-weight:900}
.tab[data-mode="css"]  .tab-badge{background:#dbeafe;color:#1d4ed8}
.tab[data-mode="js"]   .tab-badge{background:#fef3c7;color:#92400e}
.tab[data-mode="html"] .tab-badge{background:#dcfce7;color:#166534}
.engine-status{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;color:var(--gray-3);padding:4px 12px;border-radius:20px;background:var(--gray-bg);border:1px solid var(--gray-1)}
.engine-dot{width:6px;height:6px;border-radius:50%;background:#94a3b8;transition:background .3s}
.engine-dot.ready{background:#22c55e;animation:pulse 2.5s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
.opts-panel{background:var(--white);border-bottom:1px solid var(--gray-1);max-height:0;overflow:hidden;transition:max-height .28s ease}
.opts-panel.open{max-height:160px}
.opts-inner{padding:14px 32px;display:flex;align-items:center;gap:28px;flex-wrap:wrap}
.opt-group{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.opt-sep{width:1px;height:18px;background:var(--gray-1);flex-shrink:0}
.opt-sec{font-size:10px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--gray-2)}
.opt-label{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--text-s);cursor:pointer;user-select:none}
.opt-label:hover{color:var(--text)}
.opt-label input[type="checkbox"]{appearance:none;width:15px;height:15px;border:2px solid var(--gray-2);border-radius:3px;background:var(--white);cursor:pointer;position:relative;flex-shrink:0;transition:all .15s}
.opt-label input[type="checkbox"]:checked{background:var(--orange);border-color:var(--orange)}
.opt-label input[type="checkbox"]:checked::after{content:'';position:absolute;left:3px;top:1px;width:5px;height:8px;border:2px solid #fff;border-top:none;border-left:none;transform:rotate(42deg)}
.opt-select{font-family:var(--font);font-size:12px;font-weight:600;padding:3px 8px;border:1.5px solid var(--gray-1);border-radius:5px;background:var(--gray-bg);color:var(--text);outline:none;cursor:pointer}
.opt-select:focus{border-color:var(--orange)}
.editor{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:16px;min-height:0}
.pane{background:var(--white);border-radius:var(--r);box-shadow:var(--shadow);border:1px solid var(--gray-1);display:flex;flex-direction:column;overflow:hidden;transition:border-color .2s}
.pane:focus-within{border-color:var(--gray-2)}
.pane.drag-over{border-color:var(--orange);box-shadow:0 0 0 3px rgba(232,82,26,.12)}
.pane-head{padding:10px 14px;border-bottom:1px solid var(--gray-1);background:var(--gray-bg);display:flex;align-items:center;gap:8px;flex-shrink:0}
.pane-title{font-family:var(--font-h);font-size:11px;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;color:var(--gray-3)}
.pane-sz{margin-left:auto;font-size:10px;font-weight:700;padding:2px 7px;border-radius:8px}
.sz-in{background:var(--gray-1);color:var(--gray-3)}
.sz-out{background:var(--orange-l);color:var(--orange)}
.pane-actions{display:flex;gap:4px}
.icon-btn{width:26px;height:26px;border-radius:5px;border:1px solid var(--gray-1);background:var(--white);cursor:pointer;display:flex;align-items:flex-start;justify-content:center;font-size:12px;color:var(--gray-3);transition:all .15s}
.icon-btn:hover{background:var(--gray-bg);color:var(--text);border-color:var(--gray-2)}
#btn-clear-in {padding-top: 4px;} #btn-copy-icon {padding-top: 7px;} #btn-dl-icon {padding-top: 4px;}
textarea{flex:1;border:none;outline:none;resize:none;padding:14px 16px;font-family:'Consolas','Courier New',monospace;font-size:12.5px;line-height:1.7;color:var(--text);background:transparent;min-height:260px}
textarea::placeholder{color:var(--gray-2)}
#output-area{color:#1d4ed8}
.bar{background:var(--white);border-top:1px solid var(--gray-1);padding:12px 32px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;box-shadow:0 -2px 8px rgba(30,58,95,.05)}
.btn{font-family:var(--font-h);font-size:13px;font-weight:700;padding:9px 20px;border-radius:7px;border:none;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:6px;white-space:nowrap}
.btn:disabled{opacity:.45;cursor:not-allowed}
.btn-primary{background:var(--orange);color:#fff}
.btn-primary:not(:disabled):hover{background:var(--orange-h);transform:translateY(-1px);box-shadow:0 4px 14px rgba(232,82,26,.35)}
.btn-ghost{background:transparent;color:var(--gray-3);border:1.5px solid var(--gray-1)}
.btn-ghost:hover{color:var(--text);border-color:var(--gray-2);background:var(--gray-bg)}
.btn-teal{background:transparent;color:#e8521a;border:1.5px solid rgba(232,82,26,.2)}
.btn-teal:hover{background:#fff3ef}
.btn-teal.copied{color:#16a34a;border-color:rgba(22,163,74,.25);background:#f0fdf4}
.result-pill{display:none;align-items:center;gap:6px;padding:7px 14px;border-radius:7px;background:var(--orange-l);border:1.5px solid rgba(232,82,26,.18);font-family:var(--font-h);font-size:13px;font-weight:700;color:var(--orange)}
.result-pill.show{display:flex}
.result-pct{font-size:14px;font-weight:900}
.bar-hint{margin-left:auto;font-size:11px;font-weight:600;color:var(--gray-2)}
.spin{width:13px;height:13px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:rot .65s linear infinite;display:none}
.working .spin{display:block}
.working .btn-text{display:none}
@keyframes rot{to{transform:rotate(360deg)}}
#overlay{position:fixed;inset:0;background:rgba(245,247,250,.95);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;z-index:100;font-family:var(--font-h);font-size:13px;font-weight:700;color:var(--gray-3)}
#overlay.hide{display:none}
.big-spin{width:36px;height:36px;border:3px solid var(--gray-1);border-top-color:var(--orange);border-radius:50%;animation:rot .9s linear infinite}
#overlay-msg{max-width:400px;text-align:center;line-height:1.6}
.toast{position:fixed;bottom:24px;right:24px;padding:10px 18px;border-radius:8px;font-family:var(--font-h);font-size:13px;font-weight:700;box-shadow:0 4px 20px rgba(30,58,95,.15);transform:translateY(10px);opacity:0;transition:all .2s;pointer-events:none;z-index:200;max-width:360px}
.toast.ok{background:var(--white);color:var(--text);border:1px solid var(--gray-1)}
.toast.good{background:var(--orange-l);color:var(--orange);border:1px solid rgba(232,82,26,.2)}
.toast.error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}
.toast.show{transform:translateY(0);opacity:1}
@media(max-width:768px){.editor{grid-template-columns:1fr;padding:10px;gap:10px}header,.tabs-wrap,.bar,.opts-inner{padding-left:16px;padding-right:16px}.header-stats,.bar-hint{display:none}}