*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}:root{--bg:#0c0c14;--panel:#12121e;--border:rgba(255,255,255,0.07);--accent:#6c63ff;--accent2:#00e5a0;--text:#e8e8f0;--muted:rgba(255,255,255,0.35);--input-bg:#1a1a2e}html,body{height:100%}body{background:var(--bg);color:var(--text);font-family:dm sans,sans-serif;min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden}.tg-header{height:56px;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:12px;flex-shrink:0;background:rgba(12,12,20,.9);backdrop-filter:blur(10px);position:sticky;top:0;z-index:100}.tg-logo{font-family:syne,sans-serif;font-weight:800;font-size:18px;letter-spacing:-.5px;display:flex;align-items:center;gap:8px}.tg-logo a{text-decoration:none;color:inherit;display:flex;align-items:center;gap:2px}.logo-dot{color:var(--accent)}.logo-dot2{color:var(--accent2)}.header-badge{font-family:ibm plex mono,monospace;font-size:10px;background:rgba(108,99,255,.15);border:1px solid rgba(108,99,255,.3);color:var(--accent);padding:2px 8px;border-radius:3px;letter-spacing:1px;text-transform:uppercase}.header-actions{margin-left:auto;display:flex;gap:10px}.btn{padding:7px 16px;border-radius:6px;font-family:dm sans,sans-serif;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .15s}.btn-ghost{background:0 0;border:1px solid var(--border);color:var(--muted)}.btn-ghost:hover{border-color:rgba(255,255,255,.2);color:var(--text)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:#7d75ff;transform:translateY(-1px);box-shadow:0 4px 20px rgba(108,99,255,.4)}.btn-success{background:var(--accent2);color:#000}.btn-success:hover{background:#00ffb5;transform:translateY(-1px);box-shadow:0 4px 20px rgba(0,229,160,.4)}.app-body{display:flex;flex:1;height:calc(100vh - 56px);overflow:hidden}.sidebar{width:320px;flex-shrink:0;border-right:1px solid var(--border);overflow-y:auto;background:var(--panel);scrollbar-width:thin;scrollbar-color:rgba(108,99,255,.3)transparent}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-thumb{background:rgba(108,99,255,.3);border-radius:4px}.section{padding:18px 20px;border-bottom:1px solid var(--border)}.section-label{font-family:ibm plex mono,monospace;font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:14px;display:flex;align-items:center;gap:8px}.section-label::after{content:'';flex:1;height:1px;background:var(--border)}.field{margin-bottom:12px}.field label{display:block;font-size:12px;color:var(--muted);margin-bottom:5px;font-weight:500}.field input[type=text],.field textarea,.field select{width:100%;background:var(--input-bg);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:dm sans,sans-serif;font-size:13px;padding:8px 12px;outline:none;transition:border-color .15s}.field input:focus,.field textarea:focus,.field select:focus{border-color:rgba(108,99,255,.5)}.field textarea{resize:vertical;min-height:64px}.field select{cursor:pointer}.color-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.color-pick{display:flex;align-items:center;gap:8px;background:var(--input-bg);border:1px solid var(--border);border-radius:6px;padding:6px 10px;cursor:pointer;transition:border-color .15s}.color-pick:hover{border-color:rgba(108,99,255,.4)}.color-pick input[type=color]{width:24px;height:24px;border:none;background:0 0;padding:0;cursor:pointer;border-radius:4px;overflow:hidden}.color-pick span{font-family:ibm plex mono,monospace;font-size:11px;color:var(--muted)}.template-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.template-card{border:2px solid var(--border);border-radius:8px;overflow:hidden;cursor:pointer;transition:all .15s;aspect-ratio:2/1;background:var(--input-bg);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:4px}.template-card:hover{border-color:rgba(108,99,255,.5)}.template-card.active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)inset}.template-card .t-name{font-size:11px;font-weight:600;color:var(--muted)}.template-card.active .t-name{color:var(--accent)}.template-card .t-icon{font-size:20px}.badge-input-area{display:flex;gap:6px;margin-bottom:8px}.badge-input-area input{flex:1;background:var(--input-bg);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:dm sans,sans-serif;font-size:13px;padding:7px 10px;outline:none}.badge-input-area input:focus{border-color:rgba(108,99,255,.5)}.badge-input-area .btn-sm{padding:7px 12px;border-radius:6px;font-size:12px;font-weight:700;cursor:pointer;border:none;transition:all .15s}.add-keep{background:rgba(0,229,160,.15);color:var(--accent2)}.add-keep:hover{background:rgba(0,229,160,.25)}.add-out{background:rgba(255,80,80,.12);color:#ff6060}.add-out:hover{background:rgba(255,80,80,.2)}.badge-list{display:flex;flex-wrap:wrap;gap:6px;min-height:28px}.badge-item{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:700;padding:4px 10px;border-radius:4px;cursor:pointer;font-family:space mono,monospace;transition:opacity .15s}.badge-item:hover{opacity:.7}.badge-item.keep{background:rgba(0,229,160,.12);color:var(--accent2);border:1px solid rgba(0,229,160,.25)}.badge-item.out{background:rgba(255,80,80,8%);color:rgba(255,100,100,.8);border:1px solid rgba(255,80,80,.2);text-decoration:line-through}.badge-item .remove{font-size:10px;opacity:.5}.range-wrap{display:flex;align-items:center;gap:10px}.range-wrap input[type=range]{flex:1;-webkit-appearance:none;height:4px;background:var(--border);border-radius:2px;outline:none;cursor:pointer}.range-wrap input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px rgba(108,99,255,.6);cursor:pointer}.range-val{font-family:ibm plex mono,monospace;font-size:12px;color:var(--accent);min-width:32px;text-align:right}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:4px 0}.toggle-label{font-size:13px;color:var(--text)}.toggle{width:36px;height:20px;background:var(--input-bg);border:1px solid var(--border);border-radius:10px;cursor:pointer;position:relative;transition:all .2s}.toggle.on{background:rgba(108,99,255,.4);border-color:var(--accent)}.toggle::after{content:'';position:absolute;width:14px;height:14px;background:var(--muted);border-radius:50%;top:2px;left:2px;transition:all .2s}.toggle.on::after{left:18px;background:var(--accent)}.canvas-area{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px;overflow:auto;background:#080810;background-image:radial-gradient(ellipse 60% 40% at 50% 50%,rgba(108,99,255,4%) 0%,transparent 70%),linear-gradient(rgba(255,255,255,.015) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.015) 1px,transparent 1px);background-size:auto,40px 40px,40px 40px}.canvas-wrapper{position:relative;box-shadow:0 40px 120px rgba(0,0,0,.8),0 0 0 1px rgba(108,99,255,.2);border-radius:4px;overflow:hidden}#thumbnail{width:1280px;height:640px;position:relative;overflow:hidden;flex-shrink:0}.scale-wrap{transform-origin:top left}.zoom-label{margin-top:14px;font-family:ibm plex mono,monospace;font-size:11px;color:var(--muted);display:flex;align-items:center;gap:10px}.zoom-label span{color:var(--accent)}@keyframes travelLine{0%{left:-300px;opacity:0}20%{opacity:1}80%{opacity:1}100%{left:1400px;opacity:0}}