/*! tailwindcss v4.1.17 | MIT License | https://tailwindcss.com */@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-border-style:solid}}}:root{--color-background:#fff;--color-surface:#f9fafb;--color-card:#fff;--color-text-primary:#111827;--color-text-secondary:#6b7280;--color-text-tertiary:#9ca3af;--color-border:#e5e7eb;--color-border-light:#f3f4f6;--color-primary:#8b5cf6;--color-primary-hover:#7c3aed;--color-primary-light:#ede9fe;--color-success:#10b981;--color-error:#ef4444;--color-warning:#f59e0b;--color-info:#3b82f6;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a}[data-theme=dark]{--color-background:#0f172a;--color-surface:#1e293b;--color-card:#1e293b;--color-text-primary:#f1f5f9;--color-text-secondary:#cbd5e1;--color-text-tertiary:#94a3b8;--color-border:#334155;--color-border-light:#1e293b;--color-primary:#8b5cf6;--color-primary-hover:#a78bfa;--color-primary-light:#2e1065;--color-success:#10b981;--color-error:#ef4444;--color-warning:#f59e0b;--color-info:#3b82f6;--shadow-sm:0 1px 2px 0 #0000004d;--shadow-md:0 4px 6px -1px #0006;--shadow-lg:0 10px 15px -3px #00000080}.visible{visibility:visible}.absolute{position:absolute}.relative{position:relative}.block{display:block}.flex{display:flex}.hidden{display:none}.border{border-style:var(--tw-border-style);border-width:1px}.underline{text-decoration-line:underline}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-surface);color:var(--color-text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;transition:background-color .2s,color .2s}#root{min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-border-light)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}.contract-view-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:16px}.contract-view-modal-content{background:var(--color-card);border:1px solid var(--color-border);border-radius:16px;box-shadow:var(--shadow-lg);max-width:900px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.contract-view-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--color-border);background:var(--color-card)}.contract-view-modal-title{font-size:20px;font-weight:700;margin:0;color:var(--color-text-primary)}.contract-view-header-actions{display:flex;gap:8px;align-items:center}.contract-view-download-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--color-border);border-radius:8px;background:var(--color-surface);color:var(--color-text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.contract-view-download-btn:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary);transform:translateY(-1px)}.contract-view-close-btn{width:32px;height:32px;border-radius:8px;border:none;background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.contract-view-close-btn:hover{background:var(--color-border-light);color:var(--color-text-primary)}.contract-view-modal-body{flex:1;overflow-y:auto;padding:24px;background:#f5f5f5}.contract-view-modal-body::-webkit-scrollbar{width:8px}.contract-view-modal-body::-webkit-scrollbar-track{background:var(--color-border-light)}.contract-view-modal-body::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.contract-view-document{background:#fff;padding:40px;border-radius:8px;box-shadow:0 2px 8px #0000001a;min-height:800px}.contract-view-document-header{text-align:center;margin-bottom:32px;padding-bottom:24px;border-bottom:2px solid #333}.contract-view-document-title{font-size:28px;font-weight:700;color:#222;margin:0 0 20px}.contract-view-document-info{display:flex;flex-direction:column;gap:8px;font-size:14px;color:#666}.contract-view-document-info p{margin:0}.contract-view-document-info strong{color:#333;font-weight:600}.contract-view-section{margin-bottom:24px}.contract-view-section h3{font-size:16px;font-weight:600;color:#222;margin:0 0 12px}.contract-view-section p{font-size:14px;line-height:1.7;color:#444;margin:8px 0}.contract-view-section ul{margin:8px 0;padding-left:24px}.contract-view-section li{font-size:14px;line-height:1.7;color:#444;margin:8px 0}.contract-view-section li strong{color:#222;font-weight:600}.contract-view-signer-info{margin-top:40px;padding:24px;background:#f9f9f9;border-radius:8px;border:1px solid #e0e0e0}.contract-view-signer-info h3{font-size:16px;font-weight:600;color:#222;margin:0 0 16px}.contract-view-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.contract-view-info-item{display:flex;gap:12px}.contract-view-info-label{font-size:14px;font-weight:600;color:#666;min-width:120px}.contract-view-info-value{font-size:14px;color:#222;font-weight:500}.contract-view-signature-area{margin-top:40px;display:flex;justify-content:space-between;align-items:flex-end;padding:20px 40px;gap:40px}.contract-view-signature-block{display:flex;flex-direction:column;align-items:center;gap:12px}.contract-view-signature-label{font-size:16px;font-weight:600;color:#222;text-align:center}.contract-view-stamp{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;border:6px solid #d32f2f;border-radius:50%;background:transparent;color:#d32f2f;font-size:48px;font-weight:900;text-align:center;line-height:.8;letter-spacing:-3px;width:120px;height:120px;box-sizing:border-box;transform:rotate(-2deg);box-shadow:none;text-shadow:none}.contract-view-stamp-row{display:flex;gap:0px;line-height:.1;justify-content:center;width:100%}.contract-view-stamp-row span{line-height:1;flex:1;text-align:center}.contract-view-company-stamp{position:relative;width:120px;height:120px;transform:rotate(-2deg);display:flex;align-items:center;justify-content:center}.contract-view-company-stamp-border{position:absolute;top:0;left:0;right:0;bottom:0;border:6px solid #d32f2f;border-radius:50%;box-sizing:border-box}.contract-view-company-stamp-border:before{content:"";position:absolute;top:15px;left:15px;right:15px;bottom:15px;border:6px solid #d32f2f;border-radius:50%;box-sizing:border-box}.contract-view-company-stamp-center{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#d32f2f;font-size:28px;font-weight:900;line-height:1;gap:4px}.contract-view-modal-footer{padding:16px 24px;border-top:1px solid var(--color-border);background:var(--color-card);text-align:center}.contract-view-footer-text{margin:0;font-size:13px;color:var(--color-text-tertiary)}@media(max-width:768px){.contract-view-modal-backdrop{padding:0}.contract-view-modal-content{max-width:100%;max-height:100vh;border-radius:0}.contract-view-modal-header{flex-wrap:wrap;gap:12px}.contract-view-header-actions{width:100%;justify-content:space-between}.contract-view-document{padding:24px 16px}.contract-view-document-title{font-size:22px}.contract-view-info-grid{grid-template-columns:1fr}.contract-view-signature-area{flex-direction:column;align-items:center;gap:24px;padding:20px}}.layout-container{min-height:100vh;background-color:var(--color-background)}.layout-header{background-color:var(--color-card);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:1100;width:100%;height:64px}.header-content{max-width:1200px;margin:0 auto;padding:16px 24px;display:flex;align-items:center;justify-content:space-between;height:100%}.header-logo{display:flex;align-items:center;gap:12px}.header-logo svg{width:24px;height:24px;color:var(--color-primary)}.header-title{font-size:20px;font-weight:700;color:var(--color-text-primary);margin:0}.header-actions{display:flex;align-items:center;gap:16px}.header-welcome{font-size:14px;color:var(--color-text-secondary)}.settings-btn{padding:10px;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.settings-btn:hover{background-color:var(--color-border-light);transform:scale(1.05)}.settings-btn svg{width:20px;height:20px;color:var(--color-text-primary)}.theme-toggle-btn{padding:10px;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.theme-toggle-btn:hover{background-color:var(--color-border-light);transform:scale(1.05)}.theme-toggle-btn svg{width:20px;height:20px;color:var(--color-text-primary)}.logout-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;font-size:14px;color:var(--color-text-secondary);background-color:transparent;border:1px solid var(--color-border);border-radius:10px;cursor:pointer;transition:all .2s;white-space:nowrap}.logout-btn:hover{background-color:var(--color-surface);color:var(--color-text-primary)}.logout-btn svg{width:16px;height:16px}.layout-main-wrapper{width:100%}.layout-sidebar{position:fixed;left:0;top:64px;width:72px;height:calc(100vh - 64px);background-color:var(--color-card);border-right:1px solid var(--color-border);z-index:1000;transition:width .3s;box-shadow:var(--shadow-sm);overflow:hidden}.layout-sidebar.open{width:240px;box-shadow:var(--shadow-lg)}.sidebar-nav{padding:12px 8px;display:flex;flex-direction:column;gap:8px}.nav-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:12px;font-size:15px;color:var(--color-text-secondary);text-decoration:none;transition:all .2s;white-space:nowrap;position:relative}.layout-sidebar:not(.open) .nav-item{justify-content:center;padding:14px 12px}.nav-item:hover{background-color:var(--color-surface);color:var(--color-text-primary)}.nav-item.active{background-color:var(--color-primary-light);color:var(--color-primary);font-weight:600}.nav-item svg{width:20px;height:20px;flex-shrink:0}.layout-sidebar:not(.open) .nav-item span{opacity:0;width:0;overflow:hidden}.layout-content{max-width:1200px;margin:0 auto;background-color:var(--color-background);width:100%}.sidebar-toggle-btn{position:fixed;left:72px;top:80px;width:32px;height:48px;background-color:var(--color-card);border:1px solid var(--color-border);border-left:none;border-radius:0 10px 10px 0;cursor:pointer;transition:all .3s;z-index:1001;display:flex;align-items:center;justify-content:center;box-shadow:2px 2px 8px #0000001a}.sidebar-toggle-btn:hover{background-color:var(--color-surface);width:36px}.sidebar-toggle-btn.sidebar-open{left:240px}.sidebar-toggle-btn svg{width:18px;height:18px;color:var(--color-text-primary);transition:transform .3s}.sidebar-toggle-btn.sidebar-open svg{transform:rotate(180deg)}.mobile-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background-color:var(--color-card);border-top:1px solid var(--color-border);box-shadow:0 -2px 8px #0000001a;z-index:1100;padding:8px 0}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px 12px;flex:1;text-decoration:none;color:var(--color-text-secondary);transition:all .2s;border-radius:8px}.mobile-nav-item:hover{background-color:var(--color-surface);color:var(--color-text-primary)}.mobile-nav-item.active{color:var(--color-primary)}.mobile-nav-item svg{width:24px;height:24px;flex-shrink:0}.mobile-nav-label{font-size:12px;font-weight:500;white-space:nowrap}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px;overflow-y:auto}.modal-container{background-color:var(--color-card);border-radius:16px;box-shadow:var(--shadow-lg);max-width:600px;width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid var(--color-border)}.modal-title{font-size:20px;font-weight:700;color:var(--color-text-primary);margin:0}.modal-close-btn{padding:8px;background-color:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.modal-close-btn:hover{background-color:var(--color-surface)}.modal-close-btn svg{width:24px;height:24px;color:var(--color-text-secondary)}.modal-body{padding:24px;overflow-y:auto;flex:1}.settings-section{margin-bottom:32px}.settings-section:last-child{margin-bottom:0}.settings-section-title{font-size:16px;font-weight:600;color:var(--color-text-primary);margin-bottom:16px}.settings-form-group{margin-bottom:16px}.settings-account-grid{display:grid;grid-template-columns:30% 70%;gap:16px}.settings-account-grid .settings-form-group{margin-bottom:0}.settings-label{display:block;font-size:14px;font-weight:500;color:var(--color-text-secondary);margin-bottom:8px}.settings-input,.settings-select{width:100%;padding:12px 16px;font-size:15px;color:var(--color-text-primary);background-color:var(--color-background);border:1px solid var(--color-border);border-radius:10px;transition:all .2s}.settings-input:disabled{background-color:var(--color-surface);color:var(--color-text-tertiary);cursor:not-allowed}.settings-input:focus,.settings-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.settings-toggle-group{padding:12px 0;border-bottom:1px solid var(--color-border-light)}.settings-toggle-group:last-child{border-bottom:none}.settings-toggle-label{display:flex;justify-content:space-between;align-items:center;cursor:pointer}.settings-toggle-label span{font-size:15px;color:var(--color-text-primary)}.settings-checkbox{width:48px;height:28px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:var(--color-surface);border:2px solid var(--color-border);border-radius:14px;position:relative;cursor:pointer;transition:all .2s}.settings-checkbox:checked{background-color:var(--color-primary);border-color:var(--color-primary)}.settings-checkbox:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background-color:#fff;border-radius:50%;transition:all .2s}.settings-checkbox:checked:after{transform:translate(20px)}.settings-contract-btn{display:flex;align-items:center;gap:12px;width:100%;padding:14px 20px;font-size:15px;font-weight:500;color:var(--color-text-primary);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;cursor:pointer;transition:all .2s}.settings-contract-btn:hover{background-color:var(--color-primary);color:#fff;border-color:var(--color-primary);transform:translateY(-1px);box-shadow:var(--shadow-md)}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid var(--color-border)}.modal-cancel-btn,.modal-save-btn{padding:12px 24px;font-size:15px;font-weight:600;border-radius:10px;cursor:pointer;transition:all .2s}.modal-cancel-btn{color:var(--color-text-secondary);background-color:transparent;border:1px solid var(--color-border)}.modal-cancel-btn:hover{background-color:var(--color-surface)}.modal-save-btn{color:#fff;background-color:var(--color-primary);border:none}.modal-save-btn:hover{background-color:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}@media(max-width:768px){.header-content{padding:12px 16px}.header-title{font-size:18px}.header-welcome{display:none}.logout-btn svg{display:none}.logout-btn{padding:8px 12px;font-size:13px}.layout-sidebar,.sidebar-toggle-btn{display:none}.mobile-bottom-nav{display:flex}.layout-content{padding-bottom:80px}.modal-overlay{padding:0;align-items:flex-end}.modal-container{max-height:95vh;border-radius:16px 16px 0 0}.modal-header{padding:20px 16px}.modal-title{font-size:18px}.modal-body{padding:20px 16px}.modal-footer{padding:16px}.modal-cancel-btn,.modal-save-btn{flex:1}.settings-account-grid{grid-template-columns:1fr}.settings-account-grid .settings-form-group{grid-column:1!important}}.contract-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px}.contract-modal-content{background:var(--color-card);border:1px solid var(--color-border);border-radius:16px;box-shadow:var(--shadow-lg);max-width:900px;width:100%;height:90vh;overflow:hidden;display:flex;flex-direction:column}.contract-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--color-border);background:var(--color-card);flex-shrink:0}.contract-modal-title-group{display:flex;align-items:center;gap:12px;color:var(--color-text-primary)}.contract-modal-title{font-size:20px;font-weight:700;margin:0;color:var(--color-text-primary)}.contract-modal-close{width:32px;height:32px;border-radius:8px;border:none;background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.contract-modal-close:hover{background:var(--color-border-light);color:var(--color-text-primary)}.contract-modal-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:32px;min-height:0}.contract-modal-body::-webkit-scrollbar{width:8px}.contract-modal-body::-webkit-scrollbar-track{background:var(--color-border-light)}.contract-modal-body::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.contract-modal-body::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.contract-info-box{background:var(--color-surface);border-radius:12px;padding:20px;margin-bottom:32px}.contract-info-box p{margin:8px 0;font-size:15px;color:var(--color-text-secondary)}.contract-info-box strong{color:var(--color-text-primary);font-weight:600}.contract-section{margin-bottom:32px}.contract-section h3{font-size:17px;font-weight:600;color:var(--color-text-primary);margin:0 0 16px}.contract-section p{font-size:15px;line-height:1.7;color:var(--color-text-secondary);margin:12px 0}.contract-section ul{margin:12px 0;padding-left:24px}.contract-section li{font-size:15px;line-height:1.7;color:var(--color-text-secondary);margin:10px 0}.contract-section li strong{color:var(--color-text-primary);font-weight:600}.contract-form-area{margin-top:40px;padding-top:32px;border-top:2px solid var(--color-border)}.contract-agreement{display:flex;align-items:flex-start;margin-bottom:24px}.contract-checkbox-label{display:flex;align-items:flex-start;gap:12px;cursor:pointer;font-size:15px;line-height:1.5;color:var(--color-text-primary);font-weight:500}.contract-checkbox{width:20px;height:20px;margin-top:2px;cursor:pointer;accent-color:var(--color-primary);flex-shrink:0}.contract-form-section{display:flex;flex-direction:column;gap:20px;margin-bottom:24px}.contract-form-group{display:flex;flex-direction:column;gap:8px}.contract-signature-label{font-size:14px;font-weight:500;color:var(--color-text-primary)}.contract-signature-input{width:100%;padding:12px 16px;border:1px solid var(--color-border);border-radius:10px;background:var(--color-background);color:var(--color-text-primary);font-size:15px;transition:all .2s}.contract-signature-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.contract-signature-input:disabled{opacity:.6;cursor:not-allowed}.contract-signature-preview{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;margin:20px auto;border:6px solid #d32f2f;border-radius:50%;background:transparent;color:#d32f2f;font-size:48px;font-weight:900;text-align:center;line-height:.8;letter-spacing:-3px;width:120px;height:120px;box-sizing:border-box;transform:rotate(-2deg);box-shadow:none;text-shadow:none}.contract-signature-row{display:flex;gap:0px;line-height:.1;justify-content:center;width:100%}.contract-signature-row span{line-height:1;flex:1;text-align:center}.contract-company-stamp{position:relative;width:120px;height:120px;transform:rotate(-2deg);display:flex;align-items:center;justify-content:center}.contract-company-stamp-border{position:absolute;top:0;left:0;right:0;bottom:0;border:6px solid #d32f2f;border-radius:50%;box-sizing:border-box}.contract-company-stamp-border:before{content:"";position:absolute;top:15px;left:15px;right:15px;bottom:15px;border:6px solid #d32f2f;border-radius:50%;box-sizing:border-box}.contract-company-stamp-center{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#d32f2f;font-size:28px;font-weight:900;line-height:1;gap:4px}.contract-actions{display:flex;gap:12px;margin-top:32px;padding-bottom:8px}.contract-btn{flex:1;padding:14px 24px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.contract-btn:disabled{opacity:.6;cursor:not-allowed}.contract-btn-secondary{background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border)}.contract-btn-secondary:hover:not(:disabled){background:var(--color-border-light)}.contract-btn-primary{background:var(--color-primary);color:#fff}.contract-btn-primary:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px)}@media(max-width:768px){.contract-modal-backdrop{padding:0}.contract-modal-content{width:100%;max-width:100%;height:100vh;border-radius:0;border:none}.contract-modal-header{padding:16px 20px}.contract-modal-body{padding:24px 20px}.contract-modal-title{font-size:18px}.contract-section h3{font-size:16px}.contract-section p,.contract-section li{font-size:14px}.contract-actions{flex-direction:column}.contract-btn{width:100%}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);padding:24px}.login-content{width:100%;max-width:440px}.login-header{text-align:center;margin-bottom:32px}.login-logo{display:inline-flex;align-items:center;gap:12px;margin-bottom:16px}.login-logo svg{color:#fffffff2}.login-title{font-size:32px;font-weight:700;color:#fff;margin:0}.login-subtitle{font-size:15px;color:#ffffffe6;margin:8px 0 0}.login-card{background-color:var(--color-card);border-radius:20px;box-shadow:var(--shadow-lg);padding:40px 32px;border:1px solid var(--color-border)}.login-form{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column}.form-label{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:8px}.form-input{width:100%;padding:12px 16px;font-size:15px;color:var(--color-text-primary);background-color:var(--color-background);border:1px solid var(--color-border);border-radius:12px;transition:all .2s}.login-button{width:100%;padding:14px 20px;font-size:16px;font-weight:600;color:#fff;background-color:var(--color-primary);border:none;border-radius:12px;cursor:pointer;transition:all .2s}.login-button:hover:not(:disabled){background-color:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.login-button:disabled{opacity:.5;cursor:not-allowed}.login-error{padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:12px;color:var(--color-text-primary);font-size:14px;text-align:center}.login-divider{position:relative;text-align:center;margin:24px 0}.login-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:var(--color-border)}.login-divider span{position:relative;background:var(--color-card);padding:0 12px;font-size:13px;color:var(--color-text-tertiary)}.google-login-button{width:100%;padding:12px 20px;font-size:15px;font-weight:500;color:var(--color-text-primary);background-color:var(--color-card);border:1px solid var(--color-border);border-radius:12px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:16px}.google-login-button:hover:not(:disabled){background-color:var(--color-background);border-color:var(--color-primary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.google-login-button:disabled{opacity:.5;cursor:not-allowed}.google-login-button svg{flex-shrink:0}.forgot-password{text-align:center;font-size:14px}.forgot-password a{color:var(--color-primary);text-decoration:none;transition:all .2s}.forgot-password a:hover{color:var(--color-primary-hover);text-decoration:underline}.login-info{margin-top:24px;text-align:center;display:flex;flex-direction:column;gap:8px}.login-info p{font-size:13px;color:#ffffffd9;margin:0}.theme-toggle{position:fixed;top:24px;right:24px;padding:12px;background-color:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:12px;cursor:pointer;transition:all .2s;z-index:100}.theme-toggle:hover{background-color:#ffffff40;transform:scale(1.05)}.theme-toggle svg{color:#fff;display:block}@media(max-width:640px){.login-container{padding:16px}.login-card{padding:32px 24px}.login-title{font-size:28px}.theme-toggle{top:16px;right:16px;padding:10px}}.dashboard-container{padding:24px;max-width:1400px;margin:0 auto}.dashboard-title{font-size:28px;font-weight:700;color:var(--color-text-primary);margin-bottom:24px}.summary-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:32px;align-items:stretch}.summary-card{background-color:var(--color-card);border:1px solid var(--color-border);border-radius:16px;padding:32px 24px;box-shadow:var(--shadow-sm);transition:all .2s;text-align:center;height:180px;display:flex;flex-direction:column;justify-content:space-between}.summary-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.summary-label{font-size:14px;font-weight:500;color:var(--color-text-secondary);margin:0;padding:0;line-height:1.4;flex-shrink:0;height:20px}.summary-value{font-size:32px;font-weight:700;color:var(--color-text-primary);margin:0;padding:0;line-height:1;flex:1;display:flex;align-items:center;justify-content:center}.summary-value.primary{color:var(--color-primary)}.summary-value.highlight{color:var(--color-success)}.summary-subtext{font-size:12px;color:var(--color-text-tertiary);margin:0;padding:0;line-height:1.4;flex-shrink:0;height:17px}.chart-card{background-color:var(--color-card);border:1px solid var(--color-border);border-radius:16px;padding:24px;box-shadow:var(--shadow-sm);margin-bottom:32px}.top-characters-card{background-color:var(--color-card);border:1px solid var(--color-border);border-radius:16px;padding:24px;box-shadow:var(--shadow-sm);margin-bottom:32px}.section-title{font-size:18px;font-weight:600;color:var(--color-text-primary);margin-bottom:16px}.top-characters-list{display:flex;flex-direction:column;gap:12px}.top-character-item{display:flex;align-items:center;gap:16px;padding:16px;background-color:var(--color-surface);border-radius:12px;transition:all .2s}.top-character-item:hover{background-color:var(--color-border-light);transform:translate(4px)}.character-rank{font-size:18px;font-weight:700;color:var(--color-primary);min-width:40px;text-align:center}.character-avatar{width:48px;height:48px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid var(--color-border)}.character-info{flex:1}.character-name{font-size:16px;font-weight:600;color:var(--color-text-primary);margin-bottom:4px}.character-stats{display:flex;gap:16px;font-size:14px;color:var(--color-text-secondary)}@media(max-width:768px){.dashboard-container{padding:16px}.dashboard-title{font-size:24px}.summary-cards{grid-template-columns:1fr;gap:16px}.summary-card{padding:24px 20px}.summary-value{font-size:28px}.chart-card,.top-characters-card{padding:20px}.top-character-item{padding:12px;gap:12px}.character-rank{font-size:16px;min-width:36px}.character-avatar{width:40px;height:40px}.character-name{font-size:15px}.character-stats{flex-direction:column;gap:4px;font-size:13px}}.revenue-container{padding:24px;max-width:1400px;margin:0 auto}.revenue-header{margin-bottom:24px}.revenue-tabs{display:flex;gap:8px;margin-top:16px}.revenue-tab{padding:10px 20px;border:1px solid var(--color-border);border-radius:8px;background-color:var(--color-surface);color:var(--color-text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.revenue-tab:hover{border-color:var(--color-primary);color:var(--color-text-primary)}.revenue-tab.active{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.revenue-title{font-size:28px;font-weight:700;color:var(--color-text-primary);margin-bottom:16px}.revenue-filters{display:flex;flex-wrap:wrap;gap:16px;align-items:flex-end;padding:20px;background-color:var(--color-card);border:1px solid var(--color-border);border-radius:12px;box-shadow:var(--shadow-sm)}.filter-group{display:flex;flex-direction:column;gap:8px;min-width:160px}.filter-label{font-size:13px;font-weight:500;color:var(--color-text-secondary)}.filter-select{padding:10px 14px;border:1px solid var(--color-border);border-radius:8px;background-color:var(--color-surface);color:var(--color-text-primary);font-size:14px;cursor:pointer;transition:all .2s}.filter-select:hover{border-color:var(--color-primary)}.filter-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #8b5cf61a}.download-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background-color:var(--color-primary);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;margin-left:auto}.download-btn:hover{background-color:var(--color-primary-hover);transform:translateY(-1px)}.revenue-table-card{background-color:var(--color-card);border:1px solid var(--color-border);border-radius:12px;padding:24px;box-shadow:var(--shadow-sm);margin-bottom:24px}.revenue-table-wrapper{overflow-x:auto}.revenue-table{width:100%;border-collapse:collapse}.revenue-table thead tr{border-bottom:2px solid var(--color-border)}.revenue-table th{text-align:left;padding:14px 16px;font-size:14px;font-weight:600;color:var(--color-text-secondary);white-space:nowrap}.revenue-table tbody tr{border-bottom:1px solid var(--color-border-light);transition:background-color .2s}.revenue-table tbody tr:hover{background-color:var(--color-surface)}.revenue-table td{padding:14px 16px;font-size:14px;color:var(--color-text-primary)}.revenue-table tfoot tr{border-top:2px solid var(--color-border);font-weight:600}.revenue-table tfoot td{padding:14px 16px;font-size:14px;color:var(--color-text-primary)}.character-cell{display:flex;align-items:center;gap:12px}.character-img{width:40px;height:40px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid var(--color-border)}.character-name-text{font-weight:500}.rank-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:13px;font-weight:600;white-space:nowrap}.rank-badge.rank-1{background-color:#ffd70026;color:gold}.rank-badge.rank-2{background-color:#c0c0c026;color:silver}.rank-badge.rank-3{background-color:#cd7f3226;color:#cd7f32}.rank-badge.rank-other{background-color:var(--color-surface);color:var(--color-text-secondary)}.text-muted{color:var(--color-text-tertiary);font-style:italic}.revenue-cards{display:none}.revenue-card{background-color:var(--color-card);border:1px solid var(--color-border);border-radius:12px;padding:20px;margin-bottom:16px;box-shadow:var(--shadow-sm)}.revenue-card-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--color-border-light)}.revenue-card-img{width:48px;height:48px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid var(--color-border)}.revenue-card-name{flex:1;font-size:16px;font-weight:600;color:var(--color-text-primary)}.revenue-card-stats{display:flex;flex-direction:column;gap:12px}.revenue-stat-item{display:flex;justify-content:space-between;align-items:center}.revenue-stat-label{font-size:14px;color:var(--color-text-secondary)}.revenue-stat-value{font-size:15px;font-weight:600;color:var(--color-text-primary)}.empty-state{padding:60px 20px;text-align:center}.empty-state-text{font-size:15px;color:var(--color-text-tertiary)}.chart-card{background-color:var(--color-card);border:1px solid var(--color-border);border-radius:12px;padding:24px;box-shadow:var(--shadow-sm);margin-bottom:24px}.chart-title{font-size:18px;font-weight:600;color:var(--color-text-primary);margin-bottom:16px}.chart-placeholder{height:256px;display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary);background-color:var(--color-surface);border-radius:12px;border:2px dashed var(--color-border)}.market-summary-card{display:flex;gap:24px;padding:20px 24px;background-color:var(--color-card);border:1px solid var(--color-border);border-radius:12px;margin-bottom:24px}.market-summary-item{display:flex;flex-direction:column;gap:4px}.market-summary-label{font-size:13px;color:var(--color-text-secondary)}.market-summary-value{font-size:20px;font-weight:700;color:var(--color-text-primary)}.market-character-list{display:flex;flex-direction:column;gap:16px}.market-character-card{background-color:var(--color-card);border:1px solid var(--color-border);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm)}.market-character-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;cursor:pointer;transition:background-color .2s}.market-character-header:hover{background-color:var(--color-surface)}.market-character-info{display:flex;align-items:center;gap:12px}.market-character-img{width:48px;height:48px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid var(--color-border)}.market-character-text{display:flex;flex-direction:column;gap:4px}.market-character-name{font-size:16px;font-weight:600;color:var(--color-text-primary);margin:0}.market-character-stats{font-size:13px;color:var(--color-text-secondary);margin:0}.market-expand-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;border-radius:6px;transition:all .2s}.market-expand-btn:hover{background-color:var(--color-surface);color:var(--color-text-primary)}.market-assets-list{display:flex;flex-direction:column;border-top:1px solid var(--color-border-light)}.market-asset-item{display:flex;align-items:center;gap:12px;padding:12px 20px;border-bottom:1px solid var(--color-border-light)}.market-asset-item:last-child{border-bottom:none}.market-asset-thumb{width:48px;height:48px;border-radius:8px;overflow:hidden;flex-shrink:0}.market-asset-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.market-asset-placeholder{width:100%;height:100%;background-color:var(--color-surface)}.market-asset-info{flex:1;display:flex;flex-direction:column;gap:2px}.market-asset-price{font-size:14px;font-weight:500;color:var(--color-text-primary)}.market-asset-sales{font-size:12px;color:var(--color-text-tertiary)}.market-asset-revenue{font-size:15px;font-weight:600;color:var(--color-primary)}@media(max-width:768px){.revenue-container{padding:16px}.revenue-title{font-size:24px}.revenue-tabs{width:100%}.revenue-tab{flex:1;text-align:center;padding:10px 12px;font-size:13px}.revenue-filters{flex-direction:column;padding:16px;gap:12px}.filter-group{width:100%;min-width:auto}.download-btn{width:100%;justify-content:center;margin-left:0}.desktop-only{display:none}.mobile-only{display:block}.chart-card{padding:16px}.chart-placeholder{height:200px}.market-summary-card{flex-direction:column;gap:12px;padding:16px}.market-summary-item{flex-direction:row;justify-content:space-between;align-items:center}.market-summary-value{font-size:18px}.market-character-header{padding:12px 16px}.market-character-img{width:40px;height:40px}.market-character-name{font-size:15px}.market-character-stats{font-size:12px}.market-asset-item{padding:10px 16px}.market-asset-thumb{width:40px;height:40px}.market-asset-price{font-size:13px}.market-asset-revenue{font-size:14px}}.withdrawal-container{padding:24px;max-width:1200px;margin:0 auto}.withdrawal-title{font-size:28px;font-weight:700;color:var(--color-text-primary);margin-bottom:16px}.withdrawal-tabs{display:flex;gap:8px;margin-bottom:24px}.withdrawal-tab{padding:12px 24px;border:1px solid var(--color-border);border-radius:8px;background-color:var(--color-surface);color:var(--color-text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.withdrawal-tab:hover{border-color:var(--color-primary);color:var(--color-text-primary)}.withdrawal-tab.active{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.withdrawal-form-card{background-color:var(--color-card);border:1px solid var(--color-border);border-radius:16px;padding:32px;box-shadow:var(--shadow-sm);margin-bottom:32px}.withdrawal-info-section{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:24px}.available-info{display:flex;flex-direction:column;gap:8px}.available-label{font-size:14px;font-weight:500;color:var(--color-text-secondary)}.available-value{font-size:20px;font-weight:700;color:var(--color-primary)}.available-subtext{font-size:13px;color:var(--color-text-tertiary)}.form-section{margin-bottom:32px}.section-title{font-size:16px;font-weight:600;color:var(--color-text-primary);margin-bottom:16px;display:flex;align-items:center;gap:8px}.form-group{margin-bottom:16px}.account-info-grid{display:grid;grid-template-columns:30% 70%;gap:16px}.account-info-grid .form-group{margin-bottom:0}.bank-info-display{background-color:var(--color-surface);border-radius:12px;padding:20px}.bank-info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:16px}.bank-info-item{display:flex;flex-direction:column;gap:6px}.bank-info-label{font-size:13px;font-weight:500;color:var(--color-text-secondary)}.bank-info-value{font-size:15px;font-weight:600;color:var(--color-text-primary)}.btn-edit-bank{width:100%;padding:10px 16px;font-size:14px;font-weight:500;color:var(--color-primary);background-color:transparent;border:1px solid var(--color-primary);border-radius:8px;cursor:pointer;transition:all .2s}.btn-edit-bank:hover{background-color:var(--color-primary);color:#fff}.bank-info-warning{background-color:#fff3e0;border:1px solid #FFB74D;border-radius:12px;padding:20px;text-align:center}.warning-text{font-size:15px;font-weight:500;color:#f57c00;margin:0 0 16px}.btn-register-bank{padding:10px 20px;font-size:14px;font-weight:600;color:#fff;background-color:#ff9800;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.btn-register-bank:hover{background-color:#f57c00;transform:translateY(-1px);box-shadow:0 4px 8px #f57c0033}.empty-state{padding:60px 20px;text-align:center;color:var(--color-text-secondary);font-size:15px}.form-label{display:block;font-size:14px;font-weight:500;color:var(--color-text-secondary);margin-bottom:8px}.form-input{width:100%;padding:12px 16px;font-size:15px;color:var(--color-text-primary);background-color:var(--color-background);border:1px solid var(--color-border);border-radius:10px;transition:all .2s}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.form-input::-moz-placeholder{color:var(--color-text-tertiary)}.form-input::placeholder{color:var(--color-text-tertiary)}.form-select{width:100%;padding:12px 16px;font-size:15px;color:var(--color-text-primary);background-color:var(--color-background);border:1px solid var(--color-border);border-radius:10px;cursor:pointer;transition:all .2s}.form-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.amount-input-wrapper{position:relative}.amount-input{padding-right:40px;font-size:18px;font-weight:600;text-align:right}.amount-unit{position:absolute;right:16px;top:50%;transform:translateY(-50%);font-size:15px;color:var(--color-text-secondary);pointer-events:none}.calculation-result{background-color:var(--color-surface);border-radius:12px;padding:20px;margin-top:16px}.calculation-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;font-size:15px}.calculation-row:not(:last-child){border-bottom:1px solid var(--color-border-light)}.calculation-label{color:var(--color-text-secondary)}.calculation-value{font-weight:600;color:var(--color-text-primary)}.calculation-value.negative{color:var(--color-error)}.calculation-value.primary{font-size:20px;color:var(--color-primary)}.calculation-divider{height:2px;background-color:var(--color-border);margin:12px 0}.checkbox-group{display:flex;align-items:center;gap:8px;margin:24px 0}.checkbox-input{width:18px;height:18px;cursor:pointer;accent-color:var(--color-primary)}.checkbox-label{font-size:14px;color:var(--color-text-secondary);cursor:pointer}.submit-btn{width:100%;padding:14px 20px;font-size:16px;font-weight:600;color:#fff;background-color:var(--color-primary);border:none;border-radius:12px;cursor:pointer;transition:all .2s}.submit-btn:hover:not(:disabled){background-color:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.history-card{background-color:var(--color-card);border:1px solid var(--color-border);border-radius:16px;padding:24px;box-shadow:var(--shadow-sm)}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;gap:16px;flex-wrap:wrap}.history-title{font-size:18px;font-weight:600;color:var(--color-text-primary)}.history-filters{display:flex;gap:12px;align-items:center}.filter-group-inline{display:flex;align-items:center;gap:8px}.filter-label-inline{font-size:13px;font-weight:500;color:var(--color-text-secondary);white-space:nowrap}.filter-select-inline{padding:8px 12px;border:1px solid var(--color-border);border-radius:8px;background-color:var(--color-surface);color:var(--color-text-primary);font-size:14px;cursor:pointer;transition:all .2s}.filter-select-inline:hover{border-color:var(--color-primary)}.filter-select-inline:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #8b5cf61a}.history-table-wrapper{overflow-x:auto}.history-table{width:100%;border-collapse:collapse}.history-table thead tr{border-bottom:2px solid var(--color-border)}.history-table th{text-align:left;padding:12px 16px;font-size:14px;font-weight:600;color:var(--color-text-secondary)}.history-table tbody tr{border-bottom:1px solid var(--color-border-light);transition:background-color .2s}.history-table tbody tr:hover{background-color:var(--color-surface)}.history-table td{padding:14px 16px;font-size:14px;color:var(--color-text-primary)}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:8px;font-size:13px;font-weight:600;background-color:#e8f5e9;color:#2e7d32}.type-badge{display:inline-block;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600;white-space:nowrap}.type-badge.chat{background-color:#8b5cf626;color:var(--color-primary)}.type-badge.market{background-color:#10b98126;color:#10b981}.history-cards{display:none}.history-card-item{background-color:var(--color-surface);border:1px solid var(--color-border-light);border-radius:12px;padding:16px;margin-bottom:12px}.history-card-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:12px;margin-bottom:12px;border-bottom:1px solid var(--color-border-light)}.history-date{font-size:14px;font-weight:600;color:var(--color-text-primary)}.history-card-body{display:flex;flex-direction:column;gap:10px}.history-row{display:flex;justify-content:space-between;align-items:center}.history-label{font-size:13px;color:var(--color-text-secondary)}.history-value{font-size:14px;font-weight:600;color:var(--color-text-primary)}.history-value.negative{color:var(--color-error)}.history-value.primary{color:var(--color-primary)}.info-section{margin-top:24px;padding:16px;background-color:var(--color-surface);border-radius:12px;display:flex;flex-direction:column;gap:8px}.info-text{font-size:13px;color:var(--color-text-secondary);margin:0}@media(max-width:768px){.withdrawal-container{padding:16px}.withdrawal-title{font-size:24px}.withdrawal-tabs{width:100%}.withdrawal-tab{flex:1;text-align:center;padding:10px 12px;font-size:13px}.withdrawal-form-card{padding:20px}.account-info-grid{grid-template-columns:1fr}.account-info-grid .form-group{grid-column:1!important}.bank-info-grid{grid-template-columns:1fr}.amount-input-wrapper{max-width:100%}.history-card{padding:16px}.history-header{flex-direction:column;align-items:flex-start}.history-filters{width:100%;flex-direction:column;gap:12px}.filter-group-inline{width:100%}.filter-select-inline{flex:1}.desktop-only{display:none}.mobile-only{display:block}.calculation-row{font-size:14px}.calculation-value.primary{font-size:18px}}
