.global-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.global-modal-box{background:#1a1a2e;border:1.5px solid rgba(212,168,67,.15);border-radius:16px;padding:28px;min-width:360px;max-width:500px;box-shadow:0 8px 32px #00000080}.global-modal-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.global-modal-header h3{flex:1;font-size:18px;font-weight:700;color:#f0d68a}.modal-icon{font-size:24px;flex-shrink:0}.modal-icon.success{color:#43a857}.modal-icon.error{color:#e63946}.modal-icon.warning{color:#f4a261}.modal-icon.info{color:#d4a843}.global-modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;color:#a09880;border-radius:8px;font-size:20px;transition:all .2s;flex-shrink:0}.global-modal-close:hover{background:#ffffff1a;color:#f0e6d3}.global-modal-content{margin-bottom:24px}.global-modal-content p{font-size:15px;color:#c0b8a8;line-height:1.6;margin:0}.global-modal-actions{display:flex;gap:12px}.global-modal-btn{flex:1;padding:14px;border-radius:10px;font-size:15px;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);border:none;cursor:pointer}.global-modal-btn.cancel{background:#0a0a0fb3;border:1.5px solid rgba(212,168,67,.15);color:#a09880}.global-modal-btn.cancel:hover{background:#0a0a0fe6;border-color:#d4a84340;color:#f0e6d3;transform:translateY(-1px)}.global-modal-btn.confirm{background:linear-gradient(135deg,#a07c2a,#d4a843);color:#0a0a0f;box-shadow:0 4px 12px #d4a8434d}.global-modal-btn.confirm:hover{transform:translateY(-2px);box-shadow:0 6px 16px #d4a84366}.auth-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.auth-modal-box{position:relative;background:linear-gradient(135deg,#1a1a2e,#16162a);border:1px solid transparent;border-radius:20px;padding:48px 40px 40px;width:90%;max-width:440px;box-shadow:0 20px 60px #000000b3,0 0 0 1px #d4a84326,inset 0 1px #ffffff0d;overflow:hidden}.auth-modal-box:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent 0%,#d4a843 20%,#f0d68a 50%,#d4a843 80%,transparent 100%);opacity:.8}.auth-modal-close{position:absolute;top:20px;right:20px;width:36px;height:36px;border-radius:50%;background:#d4a84314;color:#a09880;display:flex;align-items:center;justify-content:center;font-size:18px;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:10}.auth-modal-close:hover{background:#d4a84326;color:#f0d68a;transform:rotate(90deg);box-shadow:0 0 12px #d4a84333}.auth-modal-header{text-align:center;margin-bottom:36px}.auth-modal-header h2{font-size:28px;font-weight:700;background:linear-gradient(135deg,#f0d68a,#d4a843);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:24px;letter-spacing:.5px}.auth-mode-switch{display:inline-flex;background:#0a0a0f99;border:1px solid rgba(212,168,67,.12);border-radius:12px;padding:6px;gap:6px;box-shadow:inset 0 2px 8px #0000004d}.auth-mode-switch button{padding:10px 28px;border-radius:8px;font-size:14px;color:#8a8070;background:transparent;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;font-weight:500}.auth-mode-switch button:hover:not(.active){color:#a09880;background:#d4a8430d}.auth-mode-switch button.active{background:linear-gradient(135deg,#a07c2a,#d4a843);color:#0a0a0f;font-weight:700;box-shadow:0 4px 12px #d4a8434d,0 2px 4px #0003}.auth-form{display:flex;flex-direction:column;gap:18px}.auth-input-group{position:relative;display:flex;align-items:center;margin-bottom:8px}.auth-input-icon{position:absolute;left:18px;color:#6a6458;font-size:18px;pointer-events:none;transition:all .3s;z-index:1}.auth-input-group:focus-within .auth-input-icon{color:#d4a843;transform:scale(1.1)}.auth-input-group input{width:100%;padding:16px 18px 16px 52px;background:#0a0a0fb3;border:1.5px solid rgba(212,168,67,.15);border-radius:12px;color:#f0e6d3;font-size:15px;outline:none;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:inset 0 2px 4px #0003}.auth-input-group input:hover{border-color:#d4a84340;background:#0a0a0fcc}.auth-input-group input:focus{border-color:#d4a843;background:#0a0a0fe6;box-shadow:inset 0 2px 4px #0003,0 0 0 3px #d4a8431a,0 4px 12px #d4a84326}.auth-input-group input::placeholder{color:#6a6458;font-weight:400}.auth-error{padding:14px 16px;background:#e639461f;border:1.5px solid rgba(230,57,70,.35);border-radius:10px;color:#ff8a96;font-size:13px;text-align:center;font-weight:500;box-shadow:0 2px 8px #e6394626}.auth-submit-btn{width:100%;padding:16px;background:linear-gradient(135deg,#a07c2a,#d4a843);color:#0a0a0f;font-size:16px;font-weight:700;border-radius:12px;margin-top:12px;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 16px #d4a84359,0 2px 4px #0003;position:relative;overflow:hidden}.auth-submit-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.auth-submit-btn:hover:not(:disabled):before{left:100%}.auth-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #d4a84373,0 3px 6px #00000040}.auth-submit-btn:active:not(:disabled){transform:translateY(0)}.auth-submit-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.auth-footer{text-align:center;margin-top:28px;font-size:14px;color:#8a8070}.auth-switch-btn{color:#d4a843;font-weight:600;margin-left:6px;transition:all .3s;background:none;border:none;padding:0;text-decoration:underline;text-decoration-color:transparent;text-underline-offset:3px}.auth-switch-btn:hover{color:#f0d68a;text-decoration-color:#f0d68a}.logout-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.logout-modal-box{position:relative;background:linear-gradient(135deg,#1a1a2e,#16162a);border:1px solid transparent;border-radius:20px;padding:40px;width:90%;max-width:400px;box-shadow:0 20px 60px #000000b3,0 0 0 1px #d4a84326,inset 0 1px #ffffff0d;overflow:hidden}.logout-modal-box:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent 0%,#d4a843 20%,#f0d68a 50%,#d4a843 80%,transparent 100%);opacity:.8}.logout-modal-close{position:absolute;top:20px;right:20px;width:36px;height:36px;border-radius:50%;background:#d4a84314;color:#a09880;display:flex;align-items:center;justify-content:center;font-size:18px;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:10}.logout-modal-close:hover{background:#d4a84326;color:#f0d68a;transform:rotate(90deg);box-shadow:0 0 12px #d4a84333}.logout-modal-icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;margin:0 auto 24px;border-radius:50%;background:#d4a8431a;border:2px solid rgba(212,168,67,.2);color:#d4a843;font-size:36px}.logout-modal-content{text-align:center;margin-bottom:32px}.logout-modal-content h2{font-size:24px;font-weight:700;background:linear-gradient(135deg,#f0d68a,#d4a843);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:16px;letter-spacing:.5px}.logout-modal-content p{font-size:15px;color:#a09880;line-height:1.6}.logout-username{color:#f0d68a;font-weight:600}.logout-modal-actions{display:flex;gap:12px}.logout-btn-cancel,.logout-btn-confirm{flex:1;padding:14px;border-radius:12px;font-size:15px;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;gap:8px}.logout-btn-cancel{background:#0a0a0fb3;border:1.5px solid rgba(212,168,67,.15);color:#a09880}.logout-btn-cancel:hover{background:#0a0a0fe6;border-color:#d4a84340;color:#f0e6d3;transform:translateY(-1px)}.logout-btn-confirm{background:linear-gradient(135deg,#a07c2a,#d4a843);color:#0a0a0f;font-weight:700;box-shadow:0 4px 16px #d4a84359,0 2px 4px #0003}.logout-btn-confirm:hover{transform:translateY(-2px);box-shadow:0 6px 20px #d4a84373,0 3px 6px #00000040}.logout-btn-confirm:active{transform:translateY(0)}.home{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.particles{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.particle{position:absolute;background:var(--gold-primary);border-radius:50%;filter:blur(1px)}.home-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:48px;padding:40px 20px}.home-header{text-align:center}.home-title{font-size:42px;font-weight:700;letter-spacing:4px;margin-bottom:8px}.home-subtitle{font-size:14px;color:var(--text-muted);letter-spacing:2px}.login-link{color:#d4a843;font-weight:600;margin-left:4px;transition:color .2s;background:none;border:none;cursor:pointer;font-size:14px;letter-spacing:2px}.login-link:hover{color:#f0d68a}.user-name{color:#d4a843;font-weight:600;margin-left:4px;background:none;border:none;cursor:pointer;font-size:14px;letter-spacing:2px;transition:color .2s}.user-name:hover{color:#f0d68a}.title-line{margin:20px auto 0;width:80px;height:2px;background:linear-gradient(90deg,transparent,var(--gold-primary),transparent)}.home-cards{display:flex;gap:24px;flex-wrap:wrap;justify-content:center;max-width:1100px}.home-card{position:relative;width:300px;padding:36px 28px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:18px;overflow:hidden;transition:border-color .3s,box-shadow .3s}.home-card:hover{border-color:var(--border-glow);box-shadow:var(--shadow-hover)}.card-glow{position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at center,rgba(212,168,67,.04) 0%,transparent 60%);opacity:0;transition:opacity .4s;pointer-events:none}.home-card:hover .card-glow{opacity:1}.card-corner{position:absolute;width:16px;height:16px;border-color:var(--gold-dark);border-style:solid;border-width:0;opacity:.3;transition:opacity .3s}.home-card:hover .card-corner{opacity:.7}.card-corner.tl{top:8px;left:8px;border-top-width:1px;border-left-width:1px}.card-corner.tr{top:8px;right:8px;border-top-width:1px;border-right-width:1px}.card-corner.bl{bottom:8px;left:8px;border-bottom-width:1px;border-left-width:1px}.card-corner.br{bottom:8px;right:8px;border-bottom-width:1px;border-right-width:1px}.card-icon-wrap{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#d4a84314;border:1px solid rgba(212,168,67,.15);transition:background .3s,border-color .3s,box-shadow .3s}.home-card:hover .card-icon-wrap{background:#d4a8431f;border-color:#d4a8434d;box-shadow:0 0 20px #d4a84326}.card-icon{font-size:28px;color:var(--gold-primary)}.card-text{text-align:center}.card-text h2{font-size:20px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.card-text p{font-size:13px;color:var(--text-secondary);line-height:1.5}.card-arrow{font-size:20px;color:var(--gold-dark);opacity:0;transform:translate(-8px);transition:opacity .3s,transform .3s}.home-card:hover .card-arrow{opacity:1;transform:translate(0)}.home-footer{font-size:12px;color:var(--text-muted);letter-spacing:2px}.generator{min-height:100vh;background:#0a0a0f;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;display:flex;flex-direction:column;align-items:center;padding:40px 20px 140px;position:relative}.generator:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(212,168,67,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(212,168,67,.03) 1px,transparent 1px);background-size:40px 40px;pointer-events:none;z-index:0}.generator>*{position:relative;z-index:1}.generator img{-webkit-user-drag:none;pointer-events:none}.gen-header{position:relative;width:100%;max-width:800px;display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:40px}.btn-back-float{position:absolute;left:0;width:48px;height:48px;border-radius:50%;background:#d4a84314;border:1.5px solid rgba(212,168,67,.15);color:#d4a843;display:flex;align-items:center;justify-content:center;font-size:20px;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #0000004d}.btn-back-float:hover{background:#d4a84326;border-color:#d4a8434d;transform:translateY(-2px);box-shadow:0 6px 16px #d4a84333}.axis-name-input{flex:1;max-width:500px;padding:14px 24px;background:#1a1a2ecc;border:1.5px solid rgba(212,168,67,.15);border-radius:12px;color:#f0d68a;font-size:18px;font-weight:600;text-align:center;outline:none;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #0000004d}.axis-name-input:focus{border-color:#d4a843;background:#1a1a2ef2;box-shadow:0 4px 16px #d4a84326}.axis-name-input::placeholder{color:#6a6458;font-weight:500}.btn-new-axis{position:absolute;right:0;width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#a07c2a,#d4a843);color:#0a0a0f;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 16px #d4a84359}.btn-new-axis:hover{transform:translateY(-2px);box-shadow:0 6px 20px #d4a84373}.gen-toolbar{width:100%;max-width:1200px;display:flex;justify-content:center;margin-bottom:30px}.btn-add-section{display:flex;align-items:center;gap:8px;padding:12px 24px;background:#d4a84314;border:1.5px dashed rgba(212,168,67,.3);border-radius:12px;color:#d4a843;font-size:14px;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-add-section:hover{background:#d4a8431f;border-color:#d4a84380;transform:translateY(-2px);box-shadow:0 4px 12px #d4a84326}.gen-bottom-actions{position:fixed;bottom:40px;transform:translate(-50%);display:flex;gap:16px;padding:16px 24px;background:#1a1a2ef2;border:1.5px solid rgba(212,168,67,.15);border-radius:16px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 8px 32px #00000080;z-index:50}.action-btn{display:flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,#a07c2a,#d4a843);color:#0a0a0f;font-size:14px;font-weight:700;border-radius:10px;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #d4a8434d}.action-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #d4a84366}.action-btn:disabled{opacity:.5;cursor:not-allowed}.new-axis-modal{max-width:450px;text-align:center}.new-axis-warning{font-size:14px;color:#8a8070;margin:20px 0 30px;line-height:1.6}.new-axis-actions{display:flex;gap:12px}.btn-cancel,.btn-confirm{flex:1;padding:14px;border-radius:12px;font-size:15px;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;gap:8px}.btn-cancel{background:#0a0a0fb3;border:1.5px solid rgba(212,168,67,.15);color:#a09880}.btn-confirm{background:linear-gradient(135deg,#a07c2a,#d4a843);color:#0a0a0f;border:none}.btn-confirm:disabled{opacity:.5;cursor:not-allowed}.save-as-modal{max-width:450px;text-align:center}.save-as-content{margin:20px 0 30px}.save-as-content label{display:block;font-size:15px;color:#d4a843;margin-bottom:16px;font-weight:600}.save-as-content input{width:100%;padding:14px 20px;background:#0a0a0fb3;border:1.5px solid rgba(212,168,67,.15);border-radius:12px;color:#f0e6d3;font-size:15px;outline:none;transition:all .3s cubic-bezier(.4,0,.2,1)}.save-as-content input:focus{border-color:#d4a843;background:#0a0a0fe6;box-shadow:0 0 0 3px #d4a8431a}.save-as-content input::placeholder{color:#6a6458}.save-as-hint{font-size:13px;color:#8a8070;margin-top:12px;line-height:1.5}.save-as-actions{display:flex;gap:12px}.guide-modal{max-width:680px;max-height:85vh;overflow-y:auto;padding:32px}.guide-modal::-webkit-scrollbar{width:8px}.guide-modal::-webkit-scrollbar-track{background:#0a0a0f80;border-radius:4px}.guide-modal::-webkit-scrollbar-thumb{background:#d4a8434d;border-radius:4px;transition:background .2s}.guide-modal::-webkit-scrollbar-thumb:hover{background:#d4a84380}.guide-content{text-align:left;margin:24px 0 32px}.guide-section{margin-bottom:32px;padding:20px;background:#0a0a0f66;border:1px solid rgba(212,168,67,.08);border-radius:12px;transition:all .3s cubic-bezier(.4,0,.2,1)}.guide-section:hover{background:#0a0a0f99;border-color:#d4a84326;transform:translate(4px)}.guide-section:last-child{margin-bottom:0}.guide-section h4{font-size:17px;color:#f0d68a;margin-bottom:16px;font-weight:700;letter-spacing:.5px;display:flex;align-items:center;gap:10px}.guide-section h4:before{content:"";width:4px;height:20px;background:linear-gradient(180deg,#d4a843,#a07c2a);border-radius:2px}.guide-section ul{list-style:none;padding:0;margin:0}.guide-section li{font-size:14px;color:#c0b8a8;line-height:1.9;margin-bottom:10px;padding-left:24px;position:relative;transition:color .2s}.guide-section li:hover{color:#d0c8b0}.guide-section li:before{content:"▸";position:absolute;left:8px;color:#d4a843;font-weight:700;font-size:12px}.guide-section li strong{color:#f0e6d3;font-weight:600;background:#d4a84314;padding:2px 6px;border-radius:4px}.guide-modal .btn-gold{width:100%;max-width:200px;margin:0 auto;padding:14px 32px;background:linear-gradient(135deg,#a07c2a,#d4a843);color:#0a0a0f;font-size:15px;font-weight:700;border-radius:12px;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 16px #d4a8434d;display:block}.guide-modal .btn-gold:hover{transform:translateY(-2px);box-shadow:0 6px 20px #d4a84373}.back-confirm-modal{max-width:450px;text-align:center}.back-confirm-message{font-size:16px;color:#c0b8a8;margin:24px 0 32px;line-height:1.6}.back-confirm-actions{display:flex;gap:12px}.modal-overlay.skill-picker-overlay{z-index:1100}.modal-box{background:#1a1a2e;border:1px solid rgba(212,168,67,.15);border-radius:16px;padding:24px;min-width:360px;max-width:480px;max-height:80vh;overflow-y:auto}.modal-header h3{font-size:16px;color:#f0d68a}.btn-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;color:#a09880;border-radius:50%;font-size:14px;transition:background .2s,color .2s}.char-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:10px}.char-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 8px;background:#ffffff05;border:1px solid rgba(212,168,67,.1);border-radius:10px;cursor:pointer;transition:border-color .2s,background .2s}.char-option:hover{border-color:#d4a8434d;background:#d4a8430d}.char-head-ring{width:52px;height:52px;border-radius:50%;border:2px solid;overflow:hidden;display:flex;align-items:center;justify-content:center}.char-head-ring img{width:100%;height:100%;object-fit:cover}.char-option span{font-size:11px;color:#a09880}.skill-list{display:flex;flex-direction:column;gap:6px}.skill-option{display:flex;align-items:center;gap:12px;padding:10px 12px;background:#ffffff05;border:1px solid rgba(212,168,67,.08);border-radius:8px;cursor:pointer;transition:border-color .2s,background .2s}.skill-option:hover{border-color:#d4a84340;background:#d4a8430a}.skill-opt-icon{width:36px;height:36px;border-radius:50%;background:#d4a84314;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:2px solid transparent;transition:border-color .2s,box-shadow .2s}.skill-opt-icon.highlight{border-color:currentColor;box-shadow:0 0 8px currentColor}.skill-opt-icon img{width:24px;height:24px;object-fit:contain}.skill-opt-info{flex:1;display:flex;flex-direction:column;gap:1px}.skill-opt-name{font-size:13px;color:#f0e6d3}.skill-opt-type{font-size:10px;color:#6a6458}.skill-opt-key{font-size:12px;font-weight:700;color:#f0d68a;background:#d4a8431f;padding:2px 8px;border-radius:4px;font-family:Cascadia Code,monospace}.gen-canvas-wrap{width:100%;padding:0 24px 40px;overflow-x:auto;overflow-y:visible;display:flex;justify-content:center}.gen-canvas{position:relative;padding:30px;background:transparent;min-height:auto;width:fit-content}.gen-canvas.exporting{background:transparent}.gen-canvas.exporting *{animation:none!important;transition:none!important}.gen-canvas.exporting .sub-axis-bar{background-color:#000!important}.gen-canvas.exporting .main-bar{background-color:transparent!important;border-radius:53.5px;overflow:hidden}.gen-canvas.exporting .main-bar-wrap{overflow:hidden}.gen-canvas.exporting .main-bar:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-color:#000;clip-path:inset(.6px round 53.5px);border-radius:54px;z-index:0;transform:translate(.2px,.3px)}.gen-canvas.exporting .sub-axis-bar{clip-path:inset(2px round 27px)}.gen-canvas.exporting .main-bar-gradient,.gen-canvas.exporting .main-bar-texture,.gen-canvas.exporting .main-bar-tint{top:1px;right:1px;bottom:1px;left:1px;border-radius:52px;transform:translateY(.5px)}.gen-canvas.exporting .main-bar:after{border-radius:52px;transform:translate(.2px,.2px);box-shadow:inset 0 0 0 2px var(--border-color),inset 0 0 0 3px var(--border-color);border:none;z-index:15}.gen-canvas.exporting .sub-axis-bar:after{transform:translate(.5px,.5px);box-shadow:inset 0 0 0 2px var(--sub-axis-border-color, rgba(255, 255, 255, .5));border:none}.gen-canvas.exporting .bar-head{left:17px;width:176px;height:176px;transform:translateY(-50%);z-index:1;border-radius:53.5px;overflow:hidden}.gen-canvas.exporting .sub-head{left:10px;width:88px;height:88px}.gen-canvas.exporting .main-bar-gradient,.gen-canvas.exporting .sub-axis-gradient{opacity:1!important}.gen-canvas.exporting .sub-axes-layer{position:absolute!important;pointer-events:none!important}.gen-canvas.exporting .sub-axis-item{position:absolute!important}.gen-canvas.exporting .btn-add-step-main,.gen-canvas.exporting .btn-add-step-sub,.gen-canvas.exporting .add-btn-wrap{display:none}.gen-canvas.exporting .step-item.selected,.gen-canvas.exporting .bar-divider.selected,.gen-canvas.exporting .subaxis-anchor.selected,.gen-canvas.exporting .sub-axis-bar.selected{border-color:transparent;background:transparent}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:120px 0;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.empty-state:hover .empty-circle{border-color:#d4a84380;background:#d4a8430d;transform:scale(1.05)}.empty-circle{width:120px;height:120px;border:3px dashed rgba(212,168,67,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:48px;color:#d4a843;margin-bottom:20px;transition:all .3s cubic-bezier(.4,0,.2,1)}.empty-text{color:#8a7a5a;font-size:16px;font-weight:500;letter-spacing:1px}.rot-section{position:relative;display:inline-flex;align-items:center;gap:12px;margin-bottom:60px;margin-right:20px}.main-bar-wrap{position:relative;display:inline-flex;align-items:center;min-height:108px;min-width:300px;border-radius:54px;overflow:hidden}.main-bar{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:54px;overflow:hidden;pointer-events:none;background-color:#000}.main-bar:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:54px;border:2px solid var(--border-color);pointer-events:none;z-index:10}.main-bar-gradient{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.main-bar-texture{position:absolute;top:0;right:0;bottom:0;left:0;background-image:url(/assets/bg_texture_tile.png);background-repeat:repeat;background-size:600px auto;background-position:center 80%;mix-blend-mode:overlay;opacity:.33;z-index:0;image-rendering:pixelated;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}.main-bar-tint{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.4;mix-blend-mode:color;z-index:0}.bar-head{position:absolute;left:15px;top:50%;transform:translateY(-50%);width:180px;height:180px;z-index:1;-webkit-mask-image:linear-gradient(to right,black 60%,transparent 100%);mask-image:linear-gradient(to right,black 60%,transparent 100%)}.bar-head img{width:100%;height:100%;object-fit:cover}.bar-items{position:relative;z-index:20;display:flex;align-items:center;gap:6px;padding:0 40px 0 200px;min-height:108px}.sec-remove{position:absolute;top:4px;left:4px;width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:#e6394626;color:#e63946;border-radius:50%;font-size:10px;opacity:0;transition:opacity .2s;z-index:11}.rot-section:hover .sec-remove{opacity:1}.step-item{position:relative;display:flex;flex-direction:column;align-items:center;gap:0;cursor:pointer;flex-shrink:0;padding:4px 0;border:2px dashed transparent;border-radius:8px;transition:border-color .2s}.step-item.selected{border-color:#d4a843cc;background:#d4a8430d}.step-item.normal-width{width:72px}.step-item.highlight-width{width:90px}.step-item.sub-axis-step.normal-width{width:60px}.step-item.sub-axis-step.highlight-width{width:80px}.step-key-badge{font-size:18px;font-weight:700;color:#fff;background:var(--key-bg-color);height:24px;padding:0 12px;border-radius:12px;font-family:Cascadia Code,monospace;line-height:24px;z-index:4;white-space:nowrap;position:relative;top:2px;display:inline-block}.step-key-badge.sm{font-size:12px;height:20px;line-height:20px;padding:0 9px}.step-circle-lg{width:72px;height:72px;border-radius:50%;background:#14142380;display:flex;align-items:center;justify-content:center;transition:border-color .2s,box-shadow .2s;position:relative;overflow:hidden;margin-top:-6px;z-index:3}.step-circle-lg.normal{border:none}.step-circle-lg.highlight{border:2px solid;box-shadow:0 2px 10px #00000080}.step-circle-lg img{width:70%;height:70%;object-fit:contain;position:relative;z-index:1}.step-circle-sm{width:44px;height:44px;border-radius:50%;background:#14142380;display:flex;align-items:center;justify-content:center;transition:border-color .2s;margin-top:-4px;position:relative;z-index:3}.step-circle-sm.highlight{border:1.5px solid}.step-circle-sm img{width:65%;height:65%;object-fit:contain}.step-text{font-size:15px;font-weight:700;color:#fff;max-width:90px;text-align:center;white-space:nowrap;overflow:visible;text-overflow:ellipsis;line-height:1.3;text-shadow:-1px -1px 0 var(--text-stroke-color),1px -1px 0 var(--text-stroke-color),-1px 1px 0 var(--text-stroke-color),1px 1px 0 var(--text-stroke-color),0 2px 6px rgba(0,0,0,.9),0 0 8px rgba(0,0,0,.7);margin-top:-8px;position:relative;z-index:4}.step-text.sm{font-size:13px;font-weight:700;max-width:70px;margin-top:-6px}.step-text-input{font-size:12px;font-weight:500;color:#f0d68a;background:#0a0a0fb3;border:1px solid rgba(212,168,67,.3);border-radius:3px;text-align:center;max-width:90px;padding:1px 4px;outline:none;text-shadow:0 1px 3px rgba(0,0,0,.9)}.step-text-input.sm{font-size:10px;max-width:70px}.step-del{position:absolute;top:-2px;right:-2px;width:14px;height:14px;border-radius:50%;background:#e63946;color:#fff;font-size:9px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;z-index:5}.step-item:hover .step-del{opacity:1}.bar-divider{width:10px;height:88px;flex-shrink:0;margin:0 2px;opacity:.8;position:relative;cursor:pointer;border:2px dashed transparent;border-radius:4px;transition:border-color .2s;display:flex;align-items:center;justify-content:center;overflow:visible}.bar-divider-img{width:6px;height:84px;position:relative;background-image:url(/assets/divider.png);background-size:contain;background-repeat:no-repeat;background-position:center;image-rendering:pixelated;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}.bar-divider-color{position:absolute;top:0;right:0;bottom:0;left:0;mix-blend-mode:multiply;opacity:.8}.bar-divider.selected{border-color:#d4a843cc;background-color:#d4a8430d}.subaxis-anchor{width:12px;height:60px;flex-shrink:0;position:relative;display:flex;align-items:center;justify-content:center;cursor:pointer;border:2px dashed transparent;border-radius:4px;transition:border-color .2s}.subaxis-anchor.selected{border-color:#d4a843cc;background:#d4a8431a}.sub-axes-layer{position:absolute;top:10px;left:-38px;width:100%;pointer-events:none;z-index:15}.sub-axis-item{position:absolute;top:0;display:flex;flex-direction:column;align-items:flex-start;pointer-events:none}.sub-axis-item.flipped{flex-direction:column-reverse}.sub-axis-item.flipped>*{transform:translateY(30px)}.sub-axis-content{display:flex;align-items:center;gap:8px;pointer-events:auto}.v-connector{width:12px;height:130px;background-image:url(/assets/v_connector.png);background-size:contain;background-repeat:no-repeat;background-position:top center;margin-left:38px;margin-top:40px;margin-bottom:-70px;position:relative;z-index:0;image-rendering:pixelated;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}.v-connector.flipped{transform:rotate(180deg);margin-top:-46px;margin-bottom:30px;z-index:-1}.sub-axis-bar-wrap{position:relative;display:inline-flex;align-items:center;min-height:100px;min-width:150px;margin-top:-4px;margin-bottom:2px;overflow:visible;pointer-events:none}.sub-axis-bar{position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);height:58px;border-radius:29px;overflow:hidden;pointer-events:all;z-index:1;cursor:pointer;border:2px dashed transparent;transition:border-color .2s,background .2s}.sub-axis-bar.selected{border-color:#d4a843cc;background:#d4a8430d;cursor:grab}.sub-axis-bar:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:29px;border:1.5px solid;border-color:var(--sub-axis-border-color, rgba(255, 255, 255, .5));pointer-events:none;z-index:2}.sub-axis-gradient{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.sub-axis-texture{position:absolute;top:0;right:0;bottom:0;left:0;background-image:url(/assets/bg_texture_tile.png);background-repeat:repeat;background-size:400px auto;background-position:center;mix-blend-mode:overlay;opacity:.33;pointer-events:none;image-rendering:pixelated;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}.sub-axis-tint{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.35;mix-blend-mode:color;pointer-events:none}.sub-head{position:absolute;left:8px;top:50%;transform:translateY(-50%);width:90px;height:90px;z-index:1;-webkit-mask-image:linear-gradient(to right,black 60%,transparent 100%);mask-image:linear-gradient(to right,black 60%,transparent 100%);overflow:hidden;pointer-events:none}.sub-head img{width:100%;height:100%;object-fit:cover}.sub-items{position:relative;z-index:10;display:flex;align-items:center;gap:3px;padding:0 24px 0 108px;min-height:100px;pointer-events:none}.sub-items>*{pointer-events:all}.sub-remove{position:absolute;top:50%;right:4px;transform:translateY(-50%);margin-top:-29px;width:16px;height:16px;display:flex;align-items:center;justify-content:center;background:#e639461a;color:#e63946;border-radius:50%;font-size:8px;opacity:0;transition:opacity .2s;z-index:11}.sub-axis-item:hover .sub-remove{opacity:1}.add-btn-wrap{position:relative;flex-shrink:0}.btn-add-step-main{width:54px;height:54px;border-radius:50%;background:#d4a8430a;border:1.5px dashed rgba(160,124,42,.35);color:#d4a84380;font-size:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s,border-color .2s,color .2s}.btn-add-step-main:hover{background:#d4a8431a;border-color:#d4a843;color:#d4a843}.btn-add-step-sub{width:32px;height:32px;border-radius:50%;background:#d4a8430a;border:1.5px dashed rgba(160,124,42,.3);color:#d4a84366;font-size:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s,border-color .2s}.btn-add-step-sub:hover{background:#d4a84314;border-color:#a07c2a}.add-context-menu{position:fixed;bottom:auto;left:auto;transform:translate(-50%) translateY(-100%);display:flex;flex-direction:column;gap:4px;background:#1a1a2ef2;border:1px solid rgba(212,168,67,.2);border-radius:8px;padding:6px;z-index:900;white-space:nowrap;box-shadow:0 4px 16px #00000080;margin-top:-6px}.ctx-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:transparent;color:#d0c8b0;font-size:12px;border-radius:4px;transition:background .15s,color .15s;white-space:nowrap}.ctx-btn:hover{background:#d4a8431f;color:#f0d68a}.sec-divider{display:inline-flex;align-items:center;justify-content:center;padding:0 12px;vertical-align:top;margin-top:69px}.sec-divider-line{width:6px;height:84px;background-image:url(/assets/divider.png);background-size:contain;background-repeat:no-repeat;background-position:center;opacity:.6}.edit-step-modal{max-width:200px}.edit-step-content{display:flex;flex-direction:column;align-items:center;gap:24px;padding:32px 24px}.edit-step-icon-preview{width:96px;height:96px;border-radius:50%;background:linear-gradient(135deg,#d4a84326,#d4a8430d);display:flex;align-items:center;justify-content:center;border:3px solid rgba(212,168,67,.4);box-shadow:0 4px 16px #d4a84333;position:relative;transition:all .3s}.edit-step-icon-preview.clickable{cursor:pointer}.edit-step-icon-preview.clickable:hover{transform:scale(1.05);border-color:#d4a843b3;box-shadow:0 6px 20px #d4a84366}.edit-step-icon-preview.clickable:active{transform:scale(.98)}.edit-step-icon-preview:before{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:50%;padding:3px;background:linear-gradient(135deg,rgba(212,168,67,.6),transparent);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:.5}.edit-step-icon-preview img{width:64px;height:64px;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.edit-step-fields{width:100%;display:flex;flex-direction:column;gap:20px}.edit-step-field{display:flex;flex-direction:column;gap:8px}.edit-step-field label{font-size:13px;font-weight:600;color:#d4a843;text-transform:uppercase;letter-spacing:.5px}.edit-step-input{width:100%;padding:12px 16px;background:#0a0a0fcc;border:2px solid rgba(212,168,67,.25);border-radius:8px;color:#f0e6d3;font-size:15px;outline:none;transition:all .2s}.edit-step-input:focus{border-color:#d4a843;background:#0a0a0ff2;box-shadow:0 0 0 3px #d4a8431a}.edit-step-input::placeholder{color:#6a6458}.edit-step-field-toggle{display:flex;align-items:center;padding:12px 16px;background:#d4a84314;border:2px solid rgba(212,168,67,.2);border-radius:8px;transition:all .2s}.edit-step-field-toggle:hover{background:#d4a8431f;border-color:#d4a8434d}.edit-step-field-toggle label{display:flex;align-items:center;gap:12px;cursor:pointer;-webkit-user-select:none;user-select:none;width:100%}.edit-step-field-toggle input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#d4a843}.edit-step-field-toggle span{font-size:14px;font-weight:500;color:#f0e6d3}.edit-step-modal .btn-gold{width:100%;max-width:240px;margin:8px auto 0;padding:12px 24px;font-size:15px;font-weight:600;display:block;text-align:center}.drag-preview{opacity:.7;transform:translate(-50%,-50%) scale(1.05);box-shadow:0 8px 24px #0009;filter:brightness(1.2);transition:none;cursor:grabbing!important}.export-modal{max-width:500px}.export-options{display:flex;flex-direction:column;gap:16px;padding:24px 0}.export-option-btn{display:flex;align-items:center;gap:20px;padding:20px 24px;background:#0a0a0f99;border:1.5px solid rgba(212,168,67,.15);border-radius:12px;color:#f0e6d3;text-align:left;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer}.export-option-btn:hover{background:#0a0a0fcc;border-color:#d4a84366;transform:translate(4px);box-shadow:0 4px 16px #d4a84326}.export-option-icon{width:56px;height:56px;border-radius:12px;background:linear-gradient(135deg,#a07c2a26,#d4a84326);display:flex;align-items:center;justify-content:center;font-size:24px;color:#d4a843;flex-shrink:0;transition:all .3s}.export-option-btn:hover .export-option-icon{background:linear-gradient(135deg,#a07c2a40,#d4a84340);transform:scale(1.1)}.export-option-info{flex:1}.export-option-info h4{font-size:18px;font-weight:700;color:#f0d68a;margin-bottom:6px}.export-option-info p{font-size:13px;color:#8a8070;line-height:1.5}.loading-modal{text-align:center;padding:48px 40px;max-width:400px}.loading-spinner{width:80px;height:80px;margin:0 auto 24px;position:relative}.spinner-ring{width:100%;height:100%;border:4px solid rgba(212,168,67,.1);border-top-color:#d4a843;border-radius:50%;box-shadow:0 0 20px #d4a8434d}.loading-modal h3{font-size:22px;font-weight:700;background:linear-gradient(135deg,#f0d68a,#d4a843);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:12px}.loading-modal p{font-size:14px;color:#a09880;line-height:1.6}.toast{position:fixed;top:46%;transform:translate(-50%,-50%);padding:24px 48px;font-size:240px;font-weight:900;color:#d4a843;opacity:.2;z-index:15;text-align:center;pointer-events:none;white-space:nowrap}.toast-success,.toast-error{color:#d4a843}.char-modal-overlay{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;background:#000c;display:flex!important;align-items:center!important;justify-content:center!important;z-index:9999!important;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.char-modal-box{position:relative;background:#1a1a2e;border:1px solid rgba(212,168,67,.2);border-radius:16px;padding:40px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #00000080}.char-modal-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:50%;background:#ffffff0d;color:#a09880;display:flex;align-items:center;justify-content:center;font-size:18px;transition:all .2s}.char-modal-close:hover{background:#ffffff1a;color:#f0e6d3}.char-modal-header{text-align:center;margin-bottom:32px}.char-modal-header h2{font-size:22px;font-weight:600;color:#f0d68a}.char-form{display:flex;flex-direction:column;gap:24px}.char-avatar-section{display:flex;justify-content:center}.char-avatar-upload{width:150px;height:150px;border-radius:50%;border:2px dashed rgba(212,168,67,.3);display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden;transition:border-color .2s;background:#0a0a0f80}.char-avatar-upload:hover{border-color:#d4a843}.char-avatar-upload img{width:100%;height:100%;object-fit:cover}.char-avatar-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;color:#6a6458}.char-avatar-placeholder svg{font-size:32px}.char-avatar-placeholder span{font-size:13px}.char-input-group{display:flex;flex-direction:column;gap:8px}.char-input-group label{font-size:13px;color:#a09880;font-weight:500}.char-input-group input[type=text]{width:100%;padding:12px 16px;background:#0a0a0f80;border:1px solid rgba(212,168,67,.15);border-radius:8px;color:#f0e6d3;font-size:14px;outline:none;transition:border-color .2s}.char-input-group input[type=text]:focus{border-color:#d4a843}.char-color-picker{display:flex;gap:12px;align-items:center}.char-color-picker input[type=color]{width:60px;height:44px;border:1px solid rgba(212,168,67,.2);border-radius:8px;background:none;cursor:pointer;padding:4px}.char-color-picker input[type=text]{flex:1;padding:12px 16px;background:#0a0a0f80;border:1px solid rgba(212,168,67,.15);border-radius:8px;color:#f0e6d3;font-size:14px;outline:none;transition:border-color .2s;font-family:Cascadia Code,monospace}.char-preview-section{display:flex;flex-direction:column;gap:8px}.char-preview-section label{font-size:13px;color:#a09880;font-weight:500}.char-preview-bar{position:relative;display:flex;align-items:center;gap:16px;padding:16px 20px;border:1px solid;border-radius:12px;min-height:80px}.char-preview-avatar{width:50px;height:50px;border-radius:50%;overflow:hidden;flex-shrink:0}.char-preview-avatar img{width:100%;height:100%;object-fit:cover}.char-preview-bar span{font-size:16px;font-weight:600}.char-submit-btn{width:100%;padding:14px;background:linear-gradient(135deg,#a07c2a,#d4a843);color:#0a0a0f;font-size:15px;font-weight:600;border-radius:8px;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:8px;transition:opacity .2s,transform .2s}.char-submit-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.char-submit-btn:disabled{opacity:.6;cursor:not-allowed}.skill-editor-overlay{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;background:#000000d9;display:flex!important;align-items:center!important;justify-content:center!important;z-index:9999!important;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:20px}.skill-editor-box{position:relative;background:#1a1a2e;border:1.5px solid rgba(212,168,67,.2);border-radius:16px;width:90%;max-width:1000px;min-height:600px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #00000080;overflow:hidden}.skill-editor-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:50%;background:#ffffff0d;color:#a09880;display:flex;align-items:center;justify-content:center;font-size:18px;transition:all .2s;z-index:10}.skill-editor-close:hover{background:#ffffff1a;color:#f0e6d3}.skill-editor-header{padding:32px 32px 24px;border-bottom:1px solid rgba(212,168,67,.1)}.skill-editor-char-info{display:flex;align-items:center;gap:16px}.skill-editor-char-info img{width:60px;height:60px;border-radius:50%;border:2px solid rgba(212,168,67,.3);object-fit:cover}.skill-editor-char-info h2{font-size:22px;font-weight:600;color:#f0d68a;margin-bottom:4px}.skill-editor-char-info p{font-size:13px;color:#8a8070}.skill-editor-content{flex:1;overflow-y:auto;padding:32px;background:linear-gradient(135deg,#0a0a0f4d,#14141e4d)}.skill-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:20px;justify-items:center}.skill-card{position:relative;display:flex;flex-direction:column;align-items:center;cursor:pointer;padding:8px;border:2px solid transparent;border-radius:12px;transition:all .3s cubic-bezier(.4,0,.2,1);background:#0a0a0f99}.skill-card:hover{border-color:#d4a84380;background:#d4a8430d;transform:translateY(-4px);box-shadow:0 8px 16px #0000004d}.skill-card.normal-width{width:100px}.skill-card.highlight-width{width:120px}.skill-card-delete{position:absolute;top:4px;right:4px;width:24px;height:24px;border-radius:50%;background:#e6394626;border:1px solid rgba(230,57,70,.3);color:#e63946;display:flex;align-items:center;justify-content:center;font-size:11px;opacity:0;transition:all .2s;z-index:10}.skill-card:hover .skill-card-delete{opacity:1}.skill-card-delete:hover{background:#e639464d;border-color:#e6394680}.skill-card-content{display:flex;flex-direction:column;align-items:center;gap:0;width:100%}.skill-card .step-key-badge{font-size:16px;font-weight:700;color:#fff;background:var(--key-bg-color);height:22px;padding:0 10px;border-radius:11px;font-family:Cascadia Code,monospace;line-height:22px;z-index:4;white-space:nowrap;position:relative;top:2px;display:inline-block}.skill-card .step-circle-lg{width:64px;height:64px;border-radius:50%;background:#14142380;display:flex;align-items:center;justify-content:center;transition:border-color .2s,box-shadow .2s;position:relative;overflow:hidden;margin-top:-4px;z-index:3}.skill-card .step-circle-lg.normal{border:none}.skill-card .step-circle-lg.highlight{border:2px solid;box-shadow:0 2px 10px #00000080}.skill-card .step-circle-lg img{width:70%;height:70%;object-fit:contain;position:relative;z-index:1}.skill-card .step-text{font-size:13px;font-weight:700;color:#fff;text-align:center;margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:90px}.skill-card-add{width:100px;height:120px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;border:2px dashed rgba(212,168,67,.3);border-radius:12px;background:#0a0a0f4d;color:#d4a843;font-size:14px;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer}.skill-card-add svg{font-size:28px}.skill-card-add:hover{border-color:#d4a84399;background:#d4a84314;transform:translateY(-4px);box-shadow:0 8px 16px #0000004d}.skill-edit-panel{position:absolute;top:0;right:0;width:380px;height:100%;background:#16162a;border-left:1.5px solid rgba(212,168,67,.2);display:flex;flex-direction:column;box-shadow:-4px 0 24px #00000080;z-index:100}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid rgba(212,168,67,.1)}.panel-header h3{font-size:18px;font-weight:600;color:#f0d68a}.panel-close{width:28px;height:28px;border-radius:50%;background:#ffffff0d;color:#a09880;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .2s}.panel-close:hover{background:#ffffff1a;color:#f0e6d3}.panel-content{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:20px}.panel-field{display:flex;flex-direction:column;gap:8px}.panel-field label{font-size:13px;color:#a09880;font-weight:600}.panel-field input[type=text]{width:100%;padding:12px 16px;background:#0a0a0fb3;border:1px solid rgba(212,168,67,.15);border-radius:8px;color:#f0e6d3;font-size:14px;outline:none;transition:border-color .2s}.panel-field input[type=text]:focus{border-color:#d4a843}.panel-field input[type=text]::placeholder{color:#6a6458}.panel-field select{width:100%;padding:12px 16px;background:#0a0a0fb3;border:1px solid rgba(212,168,67,.15);border-radius:8px;color:#f0e6d3;font-size:14px;outline:none;transition:border-color .2s;cursor:pointer}.panel-field select:focus{border-color:#d4a843}.icon-upload-area{display:flex;flex-direction:column;gap:12px}.icon-preview{width:100%;height:120px;border-radius:12px;border:2px dashed rgba(212,168,67,.3);background:#0a0a0fb3;display:flex;align-items:center;justify-content:center;overflow:hidden;cursor:pointer;transition:all .3s;position:relative}.icon-preview:hover{border-color:#d4a84399;background:#d4a8430d}.icon-preview img{width:100%;height:100%;object-fit:cover}.icon-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;color:#6a6458}.icon-placeholder span{font-size:13px;color:#8a8070}.icon-actions{display:flex;flex-direction:column;gap:8px}.btn-upload{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;background:#d4a8431a;border:1.5px solid rgba(212,168,67,.3);border-radius:8px;color:#d4a843;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.btn-upload:hover{background:#d4a84333;border-color:#d4a84380}.panel-field-toggle{display:flex;align-items:center;padding:12px 16px;background:#0a0a0f80;border:1px solid rgba(212,168,67,.15);border-radius:8px;transition:all .2s}.panel-field-toggle:hover{background:#0a0a0fb3;border-color:#d4a84340}.panel-field-toggle label{display:flex;align-items:center;gap:12px;cursor:pointer;width:100%}.panel-field-toggle input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#d4a843}.panel-field-toggle span{font-size:14px;color:#f0e6d3;font-weight:500}.panel-footer{display:flex;gap:12px;padding:20px 24px;border-top:1px solid rgba(212,168,67,.1)}.btn-panel-cancel,.btn-panel-save{flex:1;padding:12px;border-radius:8px;font-size:14px;font-weight:600;transition:all .3s;text-align:center;display:flex;align-items:center;justify-content:center}.btn-panel-cancel{background:#0a0a0fb3;border:1.5px solid rgba(212,168,67,.15);color:#a09880}.btn-panel-cancel:hover{background:#0a0a0fe6;border-color:#d4a84340;color:#f0e6d3}.btn-panel-save{background:linear-gradient(135deg,#a07c2a,#d4a843);color:#0a0a0f;border:none;box-shadow:0 4px 12px #d4a8434d}.btn-panel-save:hover{transform:translateY(-2px);box-shadow:0 6px 16px #d4a84366}.btn-panel-save:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.skill-editor-content::-webkit-scrollbar,.panel-content::-webkit-scrollbar{width:8px}.skill-editor-content::-webkit-scrollbar-track,.panel-content::-webkit-scrollbar-track{background:#0a0a0f80;border-radius:4px}.skill-editor-content::-webkit-scrollbar-thumb,.panel-content::-webkit-scrollbar-thumb{background:#d4a8434d;border-radius:4px}.skill-editor-content::-webkit-scrollbar-thumb:hover,.panel-content::-webkit-scrollbar-thumb:hover{background:#d4a84380}.manager{min-height:100vh;background:#0a0a0f;position:relative}.manager:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(212,168,67,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(212,168,67,.02) 1px,transparent 1px);background-size:40px 40px;pointer-events:none;z-index:0}.manager>*{position:relative;z-index:1}.mgr-topbar{display:flex;align-items:center;gap:16px;padding:20px 32px;background:#1a1a2ecc;border-bottom:1px solid rgba(212,168,67,.15);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.mgr-title{font-size:22px;font-weight:700;background:linear-gradient(135deg,#f0d68a,#d4a843);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.btn-back{display:flex;align-items:center;gap:8px;padding:10px 20px;background:#d4a84314;border:1.5px solid rgba(212,168,67,.15);border-radius:10px;color:#d4a843;font-size:14px;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-back:hover{background:#d4a84326;border-color:#d4a8434d;transform:translate(-2px)}.mgr-tabs{display:flex;gap:8px;padding:0 32px;margin-top:24px;border-bottom:1px solid rgba(212,168,67,.08)}.mgr-tab{display:flex;align-items:center;gap:8px;padding:14px 24px;background:transparent;color:#8a8070;font-size:15px;font-weight:600;border-bottom:3px solid transparent;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}.mgr-tab:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#d4a8430d;border-radius:8px 8px 0 0;opacity:0;transition:opacity .3s}.mgr-tab:hover{color:#c0b8a8}.mgr-tab:hover:before{opacity:1}.mgr-tab.active{color:#f0d68a;border-bottom-color:#d4a843}.mgr-tab.active:before{opacity:1;background:#d4a84314}.resource-tabs{display:flex;gap:12px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid rgba(212,168,67,.1)}.resource-tab{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#d4a8430d;border:1px solid rgba(212,168,67,.15);border-radius:6px;color:var(--text-secondary);font-size:13px;transition:all .2s}.resource-tab:hover{background:#d4a84314;border-color:#d4a84340}.resource-tab.active{background:#d4a8431f;border-color:var(--gold-primary);color:var(--gold-primary)}.mgr-content{padding:32px;max-width:1400px;margin:0 auto}.mgr-panel{min-height:400px}.mgr-loading,.mgr-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:80px 0;color:#8a8070;font-size:16px}.preset-list{display:flex;flex-direction:column;gap:12px}.preset-card{position:relative;display:flex;align-items:center;gap:20px;padding:20px 24px 20px 140px;background:#1a1a2e99;border-width:6px;border-style:solid;border-color:#d4a843;border-radius:12px;transition:all .3s cubic-bezier(.4,0,.2,1);min-height:140px}.preset-card:hover{box-shadow:0 4px 20px #0000004d,0 0 20px var(--card-accent, #d4a843);transform:translateY(-2px);background:#1a1a2ecc}.preset-char-avatar{width:120px;height:100%;border:none;border-radius:8px 0 0 8px;overflow:hidden;margin-left:0;background:#0a0a0fcc;box-shadow:0 2px 8px #0006;transition:all .3s cubic-bezier(.4,0,.2,1);border-right:3px solid var(--char-theme, #d4a843);-webkit-mask-image:linear-gradient(to right,black 70%,transparent 100%);mask-image:linear-gradient(to right,black 70%,transparent 100%)}.preset-char-avatar:first-child{margin-left:0}.preset-info h3{font-size:28px;font-weight:700;color:#f0e6d3;margin-bottom:10px}.preset-meta{font-size:18px;color:#a09880}.preset-actions{display:flex;gap:8px}.btn-icon{width:36px;height:36px;border-radius:8px;background:#d4a84314;border:1px solid rgba(212,168,67,.15);color:#d4a843;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-icon:hover{background:#d4a84326;border-color:#d4a8434d;transform:scale(1.1)}.btn-icon.danger{background:#e6394614;border-color:#e6394626;color:#e63946}.btn-icon.danger:hover{background:#e6394626;border-color:#e639464d}.btn-icon.published{background:#43a85714;border-color:#43a85726;color:#43a857}.btn-icon.published:hover{background:#43a85726;border-color:#43a8574d}.gallery-preview-modal{max-width:600px;padding:32px}.preview-meta{display:flex;gap:24px;padding:16px;background:#0a0a0f80;border-radius:8px;font-size:14px;color:#a09880}.preview-stats{display:flex;gap:24px;padding:16px;background:#d4a84314;border:1px solid rgba(212,168,67,.15);border-radius:8px;font-size:15px;font-weight:600;color:#f0d68a}.avatar-upload{display:flex;gap:12px;margin-bottom:24px;align-items:center}.upload-area{display:flex;align-items:center;gap:8px;padding:10px 20px;background:var(--bg-card);border:1px dashed var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:13px;cursor:pointer;transition:border-color .2s}.upload-area:hover{border-color:var(--gold-dark)}.avatar-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:12px}.avatar-item{position:relative;aspect-ratio:1;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-color);transition:border-color .2s}.avatar-item:hover{border-color:var(--gold-primary)}.avatar-item img{width:100%;height:100%;object-fit:cover}.avatar-delete{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:#000000b3;color:var(--danger);font-size:11px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.avatar-item:hover .avatar-delete{opacity:1}.char-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center}.char-empty-title{font-size:24px;font-weight:600;color:#f0d68a;margin-bottom:12px}.char-empty-subtitle{font-size:16px;color:#a09880;margin-bottom:32px}.char-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.char-header h3{font-size:18px;font-weight:600;color:#f0d68a}.char-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px}.char-card{position:relative;background:#1a1a2e80;border:1px solid rgba(212,168,67,.15);border-radius:12px;padding:20px;display:flex;flex-direction:column;align-items:center;gap:16px;cursor:pointer;transition:all .3s}.char-card:hover{border-color:var(--char-color, #d4a843);box-shadow:0 4px 20px #d4a84326;transform:translateY(-4px)}.char-card-avatar{width:100px;height:100px;border-radius:50%;overflow:hidden;border:2px solid var(--char-color, #d4a843)}.char-card-avatar img{width:100%;height:100%;object-fit:cover}.char-card-info{text-align:center}.char-card-info h4{font-size:16px;font-weight:600;color:#f0e6d3;margin-bottom:4px}.char-card-skills{font-size:12px;color:#6a6458}.char-card-delete{position:absolute;top:12px;right:12px;width:28px;height:28px;border-radius:50%;background:#000000b3;color:#e63946;display:flex;align-items:center;justify-content:center;font-size:14px;opacity:0;transition:opacity .2s}.char-card:hover .char-card-delete{opacity:1}.char-card-delete:hover{background:#e6394633}.char-card-edit{position:absolute;top:12px;left:12px;width:28px;height:28px;border-radius:50%;background:#000000b3;color:#d4a843;display:flex;align-items:center;justify-content:center;font-size:13px;opacity:0;transition:opacity .2s,background .2s;z-index:10}.char-card:hover .char-card-edit{opacity:1}.char-card-edit:hover{background:#d4a8434d}.control-panel{display:flex;flex-direction:column;gap:32px}.control-section{background:#1a1a2e80;border:1.5px solid rgba(212,168,67,.12);border-radius:16px;padding:28px;transition:all .3s cubic-bezier(.4,0,.2,1)}.control-section:hover{border-color:#d4a84333;box-shadow:0 4px 24px #0003}.control-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid rgba(212,168,67,.1)}.control-header h3{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:700;color:#f0d68a}.control-header h3 svg{font-size:24px}.user-list{display:flex;flex-direction:column;gap:12px}.user-card{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;background:#0a0a0f80;border:1.5px solid rgba(212,168,67,.08);border-radius:12px;transition:all .3s cubic-bezier(.4,0,.2,1)}.user-card:hover{border-color:#d4a84333;background:#0a0a0fb3;transform:translate(4px)}.user-info{display:flex;align-items:center;gap:16px}.user-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#d4a84333,#a07c2a33);border:2px solid rgba(212,168,67,.3);display:flex;align-items:center;justify-content:center;font-size:20px;color:#d4a843}.user-details{display:flex;flex-direction:column;gap:4px}.user-details h4{font-size:16px;font-weight:600;color:#f0e6d3}.user-meta{font-size:13px;color:#8a8070}.user-actions{display:flex;align-items:center;gap:12px}.btn-role{display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-role.admin{background:linear-gradient(135deg,#d4a84326,#a07c2a26);border:1.5px solid rgba(212,168,67,.3);color:#f0d68a}.btn-role.admin:hover:not(:disabled){background:linear-gradient(135deg,#d4a84340,#a07c2a40);border-color:#d4a84380;transform:translateY(-2px)}.btn-role.user{background:#64647826;border:1.5px solid rgba(100,100,120,.3);color:#a0a8b0}.btn-role.user:hover:not(:disabled){background:#64647840;border-color:#64647880;transform:translateY(-2px)}.btn-role:disabled{opacity:.5;cursor:not-allowed}.user-modal{max-width:450px;padding:32px}.user-form{display:flex;flex-direction:column;gap:20px;margin:24px 0 32px}.form-group{display:flex;flex-direction:column;gap:10px}.form-group label{font-size:14px;font-weight:600;color:#d4a843}.form-group input{padding:14px 18px;background:#0a0a0fb3;border:1.5px solid rgba(212,168,67,.15);border-radius:10px;color:#f0e6d3;font-size:15px;outline:none;transition:all .3s cubic-bezier(.4,0,.2,1)}.form-group input:focus{border-color:#d4a843;background:#0a0a0fe6;box-shadow:0 0 0 3px #d4a8431a}.form-group input::placeholder{color:#6a6458}.btn-gold{display:flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,#a07c2a,#d4a843);color:#0a0a0f;font-size:14px;font-weight:700;border-radius:10px;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #d4a8434d}.btn-gold:hover{transform:translateY(-2px);box-shadow:0 6px 16px #d4a84366}.modal-box{background:#1a1a2e;border:1.5px solid rgba(212,168,67,.15);border-radius:16px;padding:24px;min-width:360px;max-width:480px;max-height:80vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.btn-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;color:#a09880;border-radius:8px;font-size:20px;transition:all .2s}.backup-restore-section{margin-bottom:32px;padding:20px;background:#0a0a0f66;border:1px solid rgba(212,168,67,.08);border-radius:12px}.backup-restore-section h4{font-size:16px;color:#f0d68a;margin-bottom:16px;font-weight:600}.backup-upload{display:flex;gap:12px;align-items:center}.btn-upload{display:flex;align-items:center;gap:8px;padding:12px 20px;background:#d4a84314;border:1.5px solid rgba(212,168,67,.15);border-radius:10px;color:#d4a843;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-upload:hover{background:#d4a84326;border-color:#d4a8434d}.backup-history{margin-top:24px}.backup-history h4{font-size:16px;color:#f0d68a;margin-bottom:16px;font-weight:600}.backup-empty{text-align:center;padding:40px;color:#6a6458;font-size:14px}.backup-list{display:flex;flex-direction:column;gap:12px}.backup-card{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:#0a0a0f80;border:1.5px solid rgba(212,168,67,.08);border-radius:12px;transition:all .3s cubic-bezier(.4,0,.2,1)}.backup-card:hover{border-color:#d4a84333;background:#0a0a0fb3;transform:translate(4px)}.backup-info{display:flex;align-items:center;gap:16px;flex:1}.backup-icon{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#d4a84333,#a07c2a33);border:2px solid rgba(212,168,67,.3);display:flex;align-items:center;justify-content:center;font-size:20px;color:#d4a843}.backup-details{display:flex;flex-direction:column;gap:4px}.backup-details h5{font-size:14px;font-weight:600;color:#f0e6d3}.backup-meta{font-size:12px;color:#8a8070}.backup-actions{display:flex;align-items:center;gap:8px}.hall{min-height:100vh;background:#0a0a0f}.hall-topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:#12121af2;border-bottom:1px solid rgba(212,168,67,.12);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.hall-title{font-size:18px;font-weight:600;color:#f0d68a;letter-spacing:1px}.btn-back{display:flex;align-items:center;gap:6px;padding:8px 14px;background:transparent;color:#a09880;font-size:13px;border-radius:6px;transition:color .2s,background .2s}.btn-back:hover{color:#d4a843;background:#d4a84314}.hall-content{padding:40px 24px;max-width:1400px;margin:0 auto}.hall-loading,.hall-empty{text-align:center;padding:80px 20px;color:#6a6458;font-size:14px}.hall-empty p{margin-bottom:8px}.hall-empty-hint{font-size:12px;color:#4a4438}.hall-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:24px}.preset-card{position:relative;display:flex;align-items:center;gap:20px;padding:20px 24px 20px 140px;background:#1a1a2e99;border-width:2px;border-style:solid;border-radius:12px;transition:all .3s cubic-bezier(.4,0,.2,1);min-height:140px;cursor:pointer}.preset-card:hover{box-shadow:0 4px 20px #0000004d;transform:translateY(-4px);background:#1a1a2ecc}.preset-characters{position:absolute;left:6px;top:6px;bottom:6px;display:flex;align-items:stretch;width:120px}.preset-char-avatar{width:120px;height:100%;border:none;border-radius:8px 0 0 8px;overflow:hidden;margin-left:0;background:#0a0a0fcc;box-shadow:0 2px 8px #0006;transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-mask-image:linear-gradient(to right,black 50%,transparent 100%);mask-image:linear-gradient(to right,black 50%,transparent 100%)}.preset-char-avatar img{width:100%;height:100%;object-fit:cover}.preset-card:hover .preset-char-avatar{transform:scale(1.02);box-shadow:0 4px 12px #00000080}.preset-info{flex:1}.preset-name{font-size:22px;font-weight:700;color:#f0e6d3;margin-bottom:8px}.preset-meta{display:flex;gap:16px;margin-bottom:8px}.preset-author,.preset-time{display:flex;align-items:center;gap:6px;font-size:14px;color:#a09880}.preset-stats{display:flex;gap:16px;padding-top:8px}.preset-stats span{font-size:14px;color:#8a8070;font-weight:600}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-box{background:#1a1a2e;border:1.5px solid rgba(212,168,67,.15);border-radius:16px;padding:24px;min-width:360px;max-width:90vw;max-height:90vh;overflow-y:auto}.modal-header{position:relative;display:flex;align-items:center;justify-content:center;margin-bottom:18px}.modal-header h3{font-size:18px;font-weight:700;color:#f0d68a}.btn-close{position:absolute;right:0;top:50%;transform:translateY(-50%);width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;color:#a09880;border-radius:8px;font-size:20px;transition:all .2s}.btn-close:hover{background:#ffffff1a;color:#f0e6d3}.gallery-preview-modal{max-width:90vw;padding:32px}.gallery-preview-content{display:flex;flex-direction:column;gap:20px;margin:24px 0 32px}.preview-info-row{display:flex;gap:16px}.preview-meta{flex:1;display:flex;align-items:center;justify-content:center;gap:24px;padding:16px;background:#0a0a0f80;border-radius:8px;font-size:14px;color:#a09880}.preview-stats{flex:1;display:flex;align-items:center;justify-content:center;gap:24px;padding:16px;background:#d4a84314;border:1px solid rgba(212,168,67,.15);border-radius:8px;font-size:15px;font-weight:600;color:#f0d68a}.preview-description{font-size:14px;color:#c0b8a8;line-height:1.6;padding:16px;background:#0a0a0f4d;border-radius:8px;border-left:3px solid #d4a843}.modal-actions{display:flex;gap:12px}.btn-cancel{flex:1;padding:14px;border-radius:10px;font-size:15px;font-weight:600;background:#0a0a0fb3;border:1.5px solid rgba(212,168,67,.15);color:#a09880;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-cancel:hover{background:#0a0a0fe6;border-color:#d4a84340;color:#f0e6d3;transform:translateY(-1px)}.btn-confirm{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;border-radius:10px;font-size:15px;font-weight:600;background:linear-gradient(135deg,#a07c2a,#d4a843);color:#0a0a0f;border:none;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #d4a8434d}.btn-confirm:hover{transform:translateY(-2px);box-shadow:0 6px 16px #d4a84366}.preview-image-container{padding:20px;background:#0a0a0f80;border-radius:8px;display:flex;justify-content:center;align-items:center;overflow:auto;max-height:70vh}.preview-image{max-width:100%;height:auto;display:block;border-radius:4px}.preview-no-image{padding:60px 20px;text-align:center;color:#6a6458;font-size:14px;background:#0a0a0f4d;border-radius:8px}:root{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-card: #1a1a2e;--bg-card-hover: #22223a;--bg-surface: #16162a;--gold-primary: #d4a843;--gold-light: #f0d68a;--gold-dark: #a07c2a;--gold-glow: rgba(212, 168, 67, .3);--gold-glow-strong: rgba(212, 168, 67, .6);--text-primary: #f0e6d3;--text-secondary: #a09880;--text-muted: #6a6458;--border-color: rgba(212, 168, 67, .15);--border-glow: rgba(212, 168, 67, .4);--danger: #e63946;--success: #2a9d8f;--info: #4a90d9;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 28px;--shadow-card: 0 4px 24px rgba(0, 0, 0, .4), 0 0 1px rgba(212, 168, 67, .1);--shadow-glow: 0 0 20px rgba(212, 168, 67, .15), 0 0 60px rgba(212, 168, 67, .05);--shadow-hover: 0 8px 40px rgba(0, 0, 0, .5), 0 0 30px rgba(212, 168, 67, .2);--font-main: "Segoe UI", "Microsoft YaHei", "PingFang SC", sans-serif;--font-mono: "Cascadia Code", "Fira Code", monospace}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%}body{font-family:var(--font-main);background:var(--bg-primary);color:var(--text-primary);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--gold-dark);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gold-primary)}.app-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;background:radial-gradient(ellipse at 20% 50%,rgba(212,168,67,.03) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(212,168,67,.02) 0%,transparent 50%),var(--bg-primary)}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 10px #d4a8431a}50%{box-shadow:0 0 25px #d4a8434d}}@keyframes border-glow{0%,to{border-color:#d4a84326}50%{border-color:#d4a84366}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes rotate-hue{0%{filter:hue-rotate(0deg)}to{filter:hue-rotate(360deg)}}.gold-text{background:linear-gradient(135deg,var(--gold-light),var(--gold-primary),var(--gold-dark));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.gold-border{border:1px solid var(--border-color);transition:border-color .3s ease}.gold-border:hover{border-color:var(--border-glow)}.shimmer-text{background:linear-gradient(90deg,var(--gold-dark) 0%,var(--gold-light) 25%,var(--gold-primary) 50%,var(--gold-light) 75%,var(--gold-dark) 100%);background-size:200% 100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmer 3s linear infinite}button{cursor:pointer;border:none;outline:none;font-family:var(--font-main)}a{color:var(--gold-primary);text-decoration:none}
