.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);position:relative;overflow:hidden}.auth-container:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:#0003;z-index:1}.auth-container:after{content:"";position:absolute;width:200%;height:200%;top:-50%;left:-50%;background:radial-gradient(circle,rgba(255,255,255,.1) 1px,transparent 1px);background-size:50px 50px;animation:backgroundMove 20s linear infinite;z-index:0}@keyframes backgroundMove{0%{transform:translate(0)}to{transform:translate(50px,50px)}}.auth-wrapper{position:relative;z-index:2;width:100%;max-width:400px;padding:20px}.auth-card{background:#fffffff2;border-radius:20px;padding:45px 35px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.3);box-shadow:0 20px 60px #0000004d;transition:transform .3s ease}.auth-card:hover{transform:translateY(-5px);box-shadow:0 25px 70px #00000059}.auth-header{text-align:center;margin-bottom:40px}.brand-logo{margin-bottom:20px}.brand-logo img{width:96px;height:auto}.auth-title{color:#333;font-size:28px;font-weight:700;margin-bottom:10px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-subtitle{color:#666;font-size:16px;margin:0;font-weight:400}.auth-form{margin-bottom:30px}.form-group{margin-bottom:38px}.form-label{display:block;color:#333;font-size:14px;font-weight:600;margin-bottom:10px;letter-spacing:.5px}.form-control{width:100%;height:50px;background:#f8f9fa!important;border:2px solid #e9ecef!important;border-radius:12px;color:#333;font-size:16px;padding:12px 18px;transition:all .3s ease;box-shadow:0 2px 4px #0000000d}.form-control:hover{background:#fff!important;border-color:#667eea!important;box-shadow:0 4px 8px #667eea1a}.form-control:focus{background:#fff!important;border-color:#667eea!important;color:#333;outline:none;box-shadow:0 0 0 4px #667eea26}.form-control::placeholder{color:#adb5bd}.form-icon{color:#667eea;margin-right:10px}.form-options{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.remember-me{display:flex;align-items:center;gap:8px}.remember-me input[type=checkbox]{width:18px;height:18px;accent-color:#667eea;cursor:pointer}.remember-me label{color:#666;font-size:14px;cursor:pointer}.forgot-password{color:#667eea!important;font-size:14px!important;text-decoration:none!important;transition:color .3s ease!important;padding:0!important;height:auto!important;border:none!important;background:none!important;box-shadow:none!important;cursor:pointer}.forgot-password:hover{color:#764ba2!important;transform:none!important;background:none!important;box-shadow:none!important;text-decoration:underline}.auth-submit{margin-bottom:24px}.auth-button{width:100%;height:52px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;color:#fff;font-size:17px;font-weight:600;letter-spacing:.5px;transition:all .3s ease;box-shadow:0 6px 20px #667eea59;cursor:pointer}.auth-button:hover{background:linear-gradient(135deg,#5a67d8,#6b46c1);transform:translateY(-3px);box-shadow:0 8px 25px #667eea73}.auth-button:active{transform:translateY(0)}.auth-footer{text-align:center;padding-top:24px;border-top:1px solid rgba(0,0,0,.1)}.auth-switch{margin-bottom:16px}.auth-switch p{color:#666;font-size:14px;margin:0;display:flex;align-items:center;justify-content:center;gap:8px}.switch-button{color:#667eea!important;font-weight:600!important;padding:0!important;height:auto!important;border:none!important;background:none!important;box-shadow:none!important;transition:color .3s ease!important;cursor:pointer}.switch-button:hover{color:#764ba2!important;transform:none!important;background:none!important;box-shadow:none!important;text-decoration:underline}.demo-account{color:#666;font-size:14px;margin-bottom:12px;background:#f8f9fa;padding:10px;border-radius:8px;border:1px solid #e9ecef}.demo-account strong{color:#667eea;font-weight:600}.auth-copyright{color:#999;font-size:12px;margin:0}.auth-container .ant-form-item{margin-bottom:0}.security-question-item{margin-bottom:20px}.security-answer-item{margin-top:16px}.auth-container .ant-select{width:100%!important}.auth-container .ant-select-selector{height:50px!important;background:#f8f9fa!important;border:2px solid #e9ecef!important;border-radius:12px!important;padding:8px 12px!important;display:flex!important;align-items:center!important}.auth-container .ant-select:hover .ant-select-selector{background:#fff!important;border-color:#667eea!important}.auth-container .ant-select-focused .ant-select-selector,.auth-container .ant-select-open .ant-select-selector{background:#fff!important;border-color:#667eea!important;box-shadow:0 0 0 4px #667eea26!important}.auth-container .ant-select-selection-item,.auth-container .ant-select-selection-placeholder{color:#333!important;font-size:16px!important;line-height:32px!important}.auth-container .ant-select-arrow{color:#667eea!important}.ant-select-dropdown{background:#fff!important;border-radius:12px!important;box-shadow:0 10px 40px #00000026!important;border:1px solid #e9ecef!important;padding:8px!important}.ant-select-item{border-radius:8px!important;padding:10px 12px!important;color:#333!important;font-size:15px!important;margin-bottom:4px!important;transition:all .2s ease!important}.ant-select-item:hover{background:#f8f9fa!important}.ant-select-item-option-selected{background:#667eea!important;color:#fff!important;font-weight:600!important}.ant-select-item-option-active{background:#f0f4ff!important}.form-label-small{display:block;color:#666;font-size:13px;font-weight:500;margin-bottom:8px;padding-left:4px}.security-questions-header{margin-top:20px;margin-bottom:24px;padding:16px;background:#ffffff0d;border-radius:8px;border-left:4px solid #0090e7}.security-questions-header h4{margin:0!important;font-size:16px!important;font-weight:600!important}.auth-container .ant-input-affix-wrapper{background:#f8f9fa!important;border:2px solid #e9ecef!important;border-radius:12px!important;height:50px!important}.auth-container .ant-input-affix-wrapper:hover{background:#fff!important;border-color:#667eea!important}.auth-container .ant-input-affix-wrapper:focus,.auth-container .ant-input-affix-wrapper-focused{background:#fff!important;border-color:#667eea!important;box-shadow:0 0 0 4px #667eea26!important}.auth-container .ant-input{background:transparent!important;color:#333!important;font-size:16px!important;height:auto!important;border:none!important;box-shadow:none!important;outline:none!important;padding:0!important}.auth-container .ant-input::placeholder{color:#adb5bd!important}.auth-container .ant-input-password{background:#f8f9fa!important;border:2px solid #e9ecef!important;border-radius:12px!important;height:50px!important}.auth-container .ant-input-password:hover{background:#fff!important;border-color:#667eea!important}.auth-container .ant-input-password:focus,.auth-container .ant-input-password-focused{background:#fff!important;border-color:#667eea!important;box-shadow:0 0 0 4px #667eea26!important}.auth-container .ant-input-password input{background:transparent!important;color:#fff!important;border:none!important;box-shadow:none!important;outline:none!important;padding:0!important}.auth-container .ant-input:-webkit-autofill,.auth-container .ant-input:-webkit-autofill:hover,.auth-container .ant-input:-webkit-autofill:focus,.auth-container .ant-input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 30px #4a4a4a inset!important;-webkit-text-fill-color:#ffffff!important;caret-color:#fff!important;transition:background-color 5000s ease-in-out 0s!important}.auth-container .ant-input-password input:-webkit-autofill,.auth-container .ant-input-password input:-webkit-autofill:hover,.auth-container .ant-input-password input:-webkit-autofill:focus,.auth-container .ant-input-password input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 30px #4a4a4a inset!important;-webkit-text-fill-color:#ffffff!important;caret-color:#fff!important;transition:background-color 5000s ease-in-out 0s!important}.auth-container .ant-select{height:48px!important;width:100%!important}.auth-container .ant-select .ant-select-selector{background:#4a4a4a!important;border:1px solid #6a6a6a!important;border-radius:8px!important;color:#fff!important;height:48px!important;min-height:48px!important;padding:0 40px 0 12px!important;display:flex!important;align-items:center!important;box-sizing:border-box!important;position:relative!important}.auth-container .ant-select:hover .ant-select-selector{background:#5a5a5a!important;border-color:#7a7a7a!important}.auth-container .ant-select-focused .ant-select-selector,.auth-container .ant-select-focused:hover .ant-select-selector{background:#5a5a5a!important;border-color:#0090e7!important;box-shadow:0 0 0 3px #0090e71a!important}.auth-container .ant-select .ant-select-selection-search{width:100%!important;height:100%!important}.auth-container .ant-select .ant-select-selection-placeholder{color:#fff9!important;line-height:46px!important;font-size:16px!important;padding:0!important;margin:0!important}.auth-container .ant-select .ant-select-selection-item{color:#fff!important;line-height:46px!important;font-size:16px!important;padding:0!important;margin:0!important}.auth-container .ant-select .ant-select-arrow{color:#fff9!important;right:12px!important;top:50%!important;transform:translateY(-50%)!important;font-size:12px!important}.ant-select-dropdown{background:#1e1e1ef2!important;border:1px solid #6a6a6a!important;border-radius:8px!important;-webkit-backdrop-filter:blur(10px)!important;backdrop-filter:blur(10px)!important;box-shadow:0 6px 16px #0006!important;z-index:1050!important}.ant-select-item{color:#fff!important;background:transparent!important;padding:8px 12px!important;border:none!important}.ant-select-item:hover,.ant-select-item-option-active{background:#0090e733!important;color:#fff!important}.ant-select-item-option-selected{background:#0090e74d!important;color:#fff!important;font-weight:600!important}.ant-select-item-option-selected:after{display:none!important}.ant-select-dropdown .ant-select-item-option-content{color:#fff!important}.ant-btn-primary{background:linear-gradient(135deg,#0090e7,#007acc)!important;border:none!important;border-radius:8px!important;height:48px!important;font-size:16px!important;font-weight:600!important;box-shadow:0 4px 12px #0090e74d!important}.ant-btn-primary:hover{background:linear-gradient(135deg,#007acc,#06a)!important;transform:translateY(-2px)!important;box-shadow:0 6px 20px #0090e766!important}.ant-btn-primary:active{transform:translateY(0)!important}.auth-modal .ant-modal-content{background:#000c;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}.auth-modal .ant-modal-header{background:transparent;border-bottom:1px solid rgba(255,255,255,.1)}.auth-modal .ant-modal-title{color:#fff;font-size:18px;font-weight:600}.auth-modal .ant-modal-close{color:#fff9}.auth-modal .ant-modal-close:hover{color:#fff}.auth-modal .ant-form-item-label>label{color:#fff;font-weight:500}.auth-modal .ant-input,.auth-modal .ant-input-affix-wrapper{background:#4a4a4a!important;border:1px solid #6a6a6a!important;color:#fff!important}.auth-modal .ant-input{border:none!important;box-shadow:none!important;outline:none!important;padding:0!important;background:transparent!important}.auth-modal .ant-input-password input{background:transparent!important;color:#fff!important;border:none!important;box-shadow:none!important;outline:none!important;padding:0!important}.auth-modal .ant-input:hover,.auth-modal .ant-input-affix-wrapper:hover{background:#5a5a5a!important;border-color:#7a7a7a!important}.auth-modal .ant-input:focus,.auth-modal .ant-input-affix-wrapper:focus,.auth-modal .ant-input-affix-wrapper-focused{background:#5a5a5a!important;border-color:#0090e7!important;box-shadow:0 0 0 3px #0090e71a!important}.auth-modal .ant-input::placeholder{color:#fff9!important}.ant-select{color:#fff!important}.ant-select .ant-select-selector{background:#ffffff1a!important;border:1px solid rgba(255,255,255,.2)!important;border-radius:8px!important;color:#fff!important}.ant-select:hover .ant-select-selector{background:#ffffff26!important;border-color:#ffffff4d!important}.ant-select-focused .ant-select-selector,.ant-select-focused:hover .ant-select-selector{background:#ffffff26!important;border-color:#0090e7!important;box-shadow:0 0 0 3px #0090e71a!important}.ant-select .ant-select-selection-placeholder{color:#fff9!important}.ant-select .ant-select-selection-item{color:#fff!important}.ant-select .ant-select-arrow{color:#fff9!important}.ant-select-dropdown{background:#000000e6!important;border:1px solid rgba(255,255,255,.2)!important;border-radius:8px!important;-webkit-backdrop-filter:blur(10px)!important;backdrop-filter:blur(10px)!important}.ant-select-item{color:#fff!important;background:transparent!important}.ant-select-item:hover{background:#0090e733!important}.ant-select-item-option-selected{background:#0090e74d!important;color:#fff!important}.ant-input:-webkit-autofill,.ant-input:-webkit-autofill:hover,.ant-input:-webkit-autofill:focus,.ant-input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 30px rgba(255,255,255,.1) inset!important;-webkit-text-fill-color:#ffffff!important;caret-color:#fff!important}.ant-input-password input:-webkit-autofill,.ant-input-password input:-webkit-autofill:hover,.ant-input-password input:-webkit-autofill:focus,.ant-input-password input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 30px rgba(255,255,255,.1) inset!important;-webkit-text-fill-color:#ffffff!important;caret-color:#fff!important}.auth-modal .ant-select .ant-select-selector{background:#ffffff1a!important;border:1px solid rgba(255,255,255,.2)!important;color:#fff!important}.auth-modal .ant-select:hover .ant-select-selector{background:#ffffff26!important;border-color:#ffffff4d!important}.auth-modal .ant-select-focused .ant-select-selector,.auth-modal .ant-select-focused:hover .ant-select-selector{background:#ffffff26!important;border-color:#0090e7!important;box-shadow:0 0 0 3px #0090e71a!important}.auth-modal .ant-select .ant-select-selection-placeholder{color:#fff9!important}.auth-modal .ant-select .ant-select-selection-item{color:#fff!important}.auth-modal .ant-select .ant-select-arrow{color:#fff9!important}.auth-modal .ant-input:-webkit-autofill,.auth-modal .ant-input:-webkit-autofill:hover,.auth-modal .ant-input:-webkit-autofill:focus,.auth-modal .ant-input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 30px rgba(255,255,255,.1) inset!important;-webkit-text-fill-color:#ffffff!important;caret-color:#fff!important}.auth-modal .ant-input-password input:-webkit-autofill,.auth-modal .ant-input-password input:-webkit-autofill:hover,.auth-modal .ant-input-password input:-webkit-autofill:focus,.auth-modal .ant-input-password input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 30px rgba(255,255,255,.1) inset!important;-webkit-text-fill-color:#ffffff!important;caret-color:#fff!important}.auth-container input,.auth-container input:hover,.auth-container input:focus,.auth-container input:active,.auth-container .ant-input,.auth-container .ant-input:hover,.auth-container .ant-input:focus,.auth-container .ant-input:active{background:#4a4a4a!important;border:1px solid #6a6a6a!important;color:#fff!important}.auth-container input:hover,.auth-container .ant-input:hover{background:#5a5a5a!important;border-color:#7a7a7a!important}.auth-container input:focus,.auth-container input:active,.auth-container .ant-input:focus,.auth-container .ant-input:active{background:#5a5a5a!important;border-color:#0090e7!important}.auth-container .ant-form-item-control-input-content input,.auth-container .ant-form-item-control-input-content .ant-input,.auth-container .ant-input-group-addon,.auth-container .ant-input-wrapper,.auth-container [class*=ant-input]{background:#4a4a4a!important;border-color:#6a6a6a!important;color:#fff!important}.auth-container .ant-form-item-control-input-content input:hover,.auth-container .ant-form-item-control-input-content .ant-input:hover,.auth-container [class*=ant-input]:hover{background:#5a5a5a!important;border-color:#7a7a7a!important}.auth-container .ant-form-item-control-input-content input:focus,.auth-container .ant-form-item-control-input-content .ant-input:focus,.auth-container [class*=ant-input]:focus{background:#5a5a5a!important;border-color:#0090e7!important}.auth-container input[type=text],.auth-container input[type=password],.auth-container input[type=email]{background:#4a4a4a!important;border:1px solid #6a6a6a!important;color:#fff!important;-webkit-appearance:none!important;-moz-appearance:none!important;appearance:none!important}.auth-container input[type=text]:focus,.auth-container input[type=password]:focus,.auth-container input[type=email]:focus{background:#5a5a5a!important;border-color:#0090e7!important;outline:none!important}.auth-container *{box-sizing:border-box}.auth-container input,.auth-container textarea,.auth-container select,.auth-container .ant-input,.auth-container .ant-select-selector,.auth-container .ant-input-affix-wrapper,.auth-container .ant-input-password,.auth-container [class*=input],.auth-container [class*=Input]{background-color:#4a4a4a!important;background:#4a4a4a!important;border-color:#6a6a6a!important;color:#fff!important}.auth-container .ant-input-affix-wrapper .ant-input,.auth-container .ant-input-password .ant-input,.auth-container .ant-input-affix-wrapper input,.auth-container .ant-input-password input{background:transparent!important;border:none!important;box-shadow:none!important;outline:none!important;padding:0!important;margin:0!important}.auth-container input:hover,.auth-container textarea:hover,.auth-container select:hover,.auth-container .ant-input:hover,.auth-container .ant-select-selector:hover,.auth-container .ant-input-affix-wrapper:hover,.auth-container .ant-input-password:hover,.auth-container [class*=input]:hover,.auth-container [class*=Input]:hover{background-color:#5a5a5a!important;background:#5a5a5a!important;border-color:#7a7a7a!important}.auth-container input:focus,.auth-container textarea:focus,.auth-container select:focus,.auth-container .ant-input:focus,.auth-container .ant-select-selector:focus,.auth-container .ant-input-affix-wrapper:focus,.auth-container .ant-input-password:focus,.auth-container .ant-input-affix-wrapper-focused,.auth-container .ant-select-focused .ant-select-selector,.auth-container [class*=input]:focus,.auth-container [class*=Input]:focus{background-color:#5a5a5a!important;background:#5a5a5a!important;border-color:#0090e7!important;box-shadow:0 0 0 3px #0090e71a!important}@media (max-width: 480px){.auth-wrapper{padding:16px}.auth-card{padding:30px 20px}.auth-title{font-size:22px}.form-control,.auth-button{height:44px;font-size:14px}}.upload-page{padding:24px;background:#f5f5f5;min-height:100vh}.upload-container{max-width:1200px;margin:0 auto}.upload-card{margin-bottom:24px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.upload-area{border:2px dashed #d9d9d9;border-radius:8px;background:#fafafa;text-align:center;padding:40px 20px;transition:all .3s}.upload-area:hover{border-color:#1890ff;background:#f0f8ff}.upload-area.dragover{border-color:#1890ff;background:#e6f7ff}.upload-icon{font-size:48px;color:#999;margin-bottom:16px}.upload-text{font-size:16px;color:#666;margin-bottom:8px}.upload-hint{font-size:14px;color:#999}.file-list{margin-top:24px}.file-item{display:flex;align-items:center;padding:12px;border:1px solid #e8e8e8;border-radius:6px;margin-bottom:8px;background:#fff}.file-info{flex:1;margin-left:12px}.file-name{font-weight:500;color:#333;margin-bottom:4px}.file-size{font-size:12px;color:#999}.file-actions{display:flex;gap:8px}.progress-container{margin-top:16px}.tag-input,.description-input{margin-top:8px}.upload-button{margin-top:16px;width:100%;height:40px}.upload-stats{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding:16px;background:#f8f9fa;border-radius:6px}.stat-item{text-align:center}.stat-number{font-size:24px;font-weight:700;color:#1890ff}.stat-label{font-size:12px;color:#666;margin-top:4px}.error-message{color:#ff4d4f;margin-top:8px}.success-message{color:#52c41a;margin-top:8px}.upload-tips{background:#e6f7ff;border:1px solid #91d5ff;border-radius:6px;padding:12px;margin-bottom:16px}.upload-tips h4{color:#1890ff;margin-bottom:8px}.upload-tips ul{margin:0;padding-left:20px}.upload-tips li{color:#666;margin-bottom:4px}.file-info-section{margin-top:24px}.section-header{margin-bottom:24px;padding:20px;background:linear-gradient(135deg,#f6f9fc,#fff);border-radius:12px;border:1px solid #e8e8e8}.section-title{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:700;color:#262626;margin-bottom:8px}.title-icon{font-size:20px}.file-count{font-size:14px;font-weight:500;color:#4096ff;background:#4096ff1a;padding:2px 8px;border-radius:12px}.section-description{font-size:14px;color:#8c8c8c;margin:0;line-height:1.5}.file-info-card{border-radius:12px;overflow:visible;box-shadow:0 2px 8px #0000000f;border:1px solid #f0f0f0;transition:all .3s ease}.file-info-card:hover{box-shadow:0 4px 16px #0000001f;border-color:#d9d9d9}.file-preview{width:100%;height:120px;object-fit:contain;border-radius:8px;border:1px solid #f0f0f0;background:#f8f9fa;display:block}.file-header{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #f5f5f5}.file-title{font-size:14px;font-weight:600;color:#262626;margin-bottom:6px;line-height:1.4;word-break:break-all}.file-path{display:flex;align-items:center;gap:6px;font-size:12px}.path-label{color:#8c8c8c;font-weight:500}.path-text{color:#595959;background:#f5f5f5;padding:2px 6px;border-radius:4px;font-family:Consolas,Monaco,monospace}.form-fields{display:flex;flex-direction:column;gap:16px}.field-group{display:flex;flex-direction:column;gap:8px}.field-label{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:#262626;margin-bottom:4px}.label-icon{font-size:14px}.label-text{line-height:1}.description-textarea{resize:none;border-radius:8px;border:1.5px solid #e6e6e6!important;padding:10px 12px;font-size:13px;line-height:1.5;transition:all .2s ease;pointer-events:auto!important;cursor:text!important}.description-textarea:focus{border-color:#4096ff;box-shadow:0 0 0 2px #4096ff1a}.description-textarea::placeholder{color:#bfbfbf}.tags-input{border-radius:8px;border:1.5px solid #e6e6e6!important;padding:8px 12px;font-size:13px;transition:all .2s ease;pointer-events:auto!important;cursor:text!important}.tags-input:focus{border-color:#4096ff;box-shadow:0 0 0 2px #4096ff1a}.tags-input::placeholder{color:#bfbfbf}.description-textarea,.description-textarea input,.description-textarea textarea,.tags-input,.tags-input input,.field-group input,.field-group textarea,.field-group .ant-input,.field-group .ant-input-affix-wrapper{pointer-events:auto!important;cursor:text!important;-webkit-user-select:text!important;user-select:text!important;z-index:100!important;position:relative!important}.ant-input,.ant-input:focus,.ant-input-focused,.ant-input-affix-wrapper,.ant-input-affix-wrapper-focused{pointer-events:auto!important;cursor:text!important;-webkit-user-select:text!important;user-select:text!important;z-index:100!important}.file-info-card,.file-info-card *,.form-fields,.form-fields *,.field-group,.field-group *,.ant-upload-list-item,.ant-upload-list-item-card-actions,.ant-upload,.ant-upload-list,.ant-upload-list-picture-card-container{pointer-events:auto!important}input[type=text],input[type=textarea],textarea,.ant-input,.ant-input-affix-wrapper,.description-textarea .ant-input,.tags-input .ant-input{pointer-events:auto!important;cursor:text!important;user-select:text!important;-webkit-user-select:text!important;-moz-user-select:text!important;-ms-user-select:text!important}.quick-tags{display:flex;flex-direction:column;gap:6px;margin-top:6px}.quick-tags-label{font-size:12px;color:#595959;font-weight:600}.quick-tags-list{display:flex;flex-wrap:wrap;gap:6px}.quick-tag{font-size:12px;color:#4096ff;background:#f0f8ff;border:1px solid #b3d8ff;padding:4px 8px;border-radius:12px;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none;font-weight:500}.quick-tag:hover{background:#4096ff;color:#fff;transform:translateY(-1px);box-shadow:0 2px 6px #4096ff4d}.quick-tag:active{transform:translateY(0)}.input-hint{font-size:12px;color:#8c8c8c;padding:6px 10px;background:#f8f9fa;border-radius:6px;border-left:3px solid #4096ff;margin-top:6px}.tags-preview{background:#f8f9fa;border-radius:8px;padding:12px;border:1px solid #e8e8e8}.tags-preview-label{font-size:12px;color:#595959;font-weight:600;margin-bottom:8px}.tags-container{display:flex;flex-wrap:wrap;gap:6px}.preview-tag{margin:0;border-radius:6px;font-size:12px;padding:2px 8px;border:none;font-weight:500}@media (max-width: 768px){.file-info-section .ant-col-lg-12{margin-bottom:16px}.file-preview{height:100px}.form-fields{gap:12px}.field-group{gap:6px}}.search-page{padding:0}.search-card{margin-bottom:24px}.image-input-section{display:flex;flex-direction:column;gap:16px;align-items:center;padding:24px;border:2px dashed #d9d9d9;border-radius:12px;background-color:#fafafa;min-height:300px;justify-content:center}.upload-button,.camera-button{width:120px;height:40px}.camera-section{display:flex;flex-direction:column;gap:16px;align-items:center}.webcam{width:100%;max-width:400px;height:300px;border-radius:8px;object-fit:cover}.camera-controls{display:flex;gap:12px}.take-photo-button,.cancel-button{width:100px}.current-image{display:flex;flex-direction:column;gap:16px;align-items:center}.preview-image{width:100%;max-width:400px;height:300px;object-fit:cover;border-radius:8px}.image-actions{display:flex;gap:12px}.search-button,.clear-button{width:100px}.search-results-section{padding:16px}.search-results-section h3{margin-bottom:16px;color:#333;font-size:18px;font-weight:600}.results-list{display:flex;flex-direction:column;gap:12px}.result-card{border-radius:8px;box-shadow:0 2px 8px #0000001a}.result-image-wrapper{position:relative;overflow:hidden;border-radius:6px;transition:box-shadow .3s ease;aspect-ratio:1 / 1;background:#f5f5f5}.result-image-wrapper:hover{box-shadow:0 4px 12px #00000026}.image-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease;pointer-events:none}.result-image-wrapper:hover .image-overlay{opacity:1}.similarity-score{color:#52c41a;font-weight:700;font-size:16px}.empty-results{text-align:center;padding:40px;color:#999}.empty-results p{margin:0;font-size:16px}@media (max-width: 768px){.image-input-section{padding:16px;min-height:250px}.webcam,.preview-image{height:250px}.camera-controls{flex-direction:column;width:100%}.take-photo-button,.cancel-button{width:100%}.image-actions{flex-direction:column;width:100%}.search-button,.clear-button{width:100%}}.gallery-page{padding:0}.gallery-card{margin-bottom:24px}.search-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:16px}.search-controls{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.gallery-stats{font-size:14px;color:#666;font-weight:500}.loading-container{text-align:center;padding:40px;color:#999}.image-grid{margin-top:16px}.image-grid-tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.image-card{border-radius:8px;overflow:hidden;transition:transform .3s,box-shadow .3s;height:auto;position:relative;z-index:1;margin-bottom:16px}.image-card:hover{transform:none;box-shadow:0 2px 8px #0000000f;z-index:1}.image-card .ant-card-body{padding:12px}.image-card .ant-card-actions{background:#fff;border-top:1px solid #f0f0f0;padding:12px;display:flex!important;justify-content:center!important;gap:20px}.image-card .ant-card-actions>li{margin:0!important;padding:8px 12px!important;font-size:16px!important;cursor:pointer}.image-cover-wrapper{position:relative}.image-checkbox{position:absolute;top:12px;left:12px;z-index:10;background:#ffffffe6;border-radius:4px;padding:4px}.image-card.select-mode{border:2px solid #d9d9d9;transition:border-color .3s}.image-card.selected{border-color:#1890ff;box-shadow:0 0 0 2px #1890ff33}.image-card .ant-card-cover{background:#f5f5f5;display:flex;align-items:center;justify-content:center;min-height:180px;height:180px}.gallery-image{width:100%;height:180px;object-fit:contain;border-radius:6px;display:block;background:#f5f5f5}.image-info{padding:12px 0}.image-title{font-size:14px;font-weight:600;color:#333;margin:0 0 8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.image-desc{font-size:12px;color:#666;margin:0 0 8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.image-tags{margin-bottom:8px}.no-tags{font-size:12px;color:#999}.image-meta{display:flex;justify-content:space-between;font-size:11px;color:#999}.empty-gallery{text-align:center;padding:60px 20px;color:#999}.empty-gallery p{font-size:16px;margin:0}.delete-icon{color:#ff4d4f}.delete-icon:hover{color:#ff7875}.pagination-container{display:flex;justify-content:center;margin-top:32px;padding-top:24px;border-top:1px solid #f0f0f0}.pagination-container .ant-pagination{margin:0}.ant-spin-container{min-height:300px}.edit-modal-textarea,.edit-modal-textarea .ant-input,.edit-modal-input,.edit-modal-input .ant-input{color:#000!important;background-color:#fff!important}.edit-modal-textarea::placeholder,.edit-modal-input::placeholder{color:#999!important}.search-controls .ant-input-search,.search-controls .ant-input-search .ant-input,.search-controls .ant-input{color:#000!important;background-color:#fff!important}.search-controls .ant-input::placeholder{color:#999!important}.search-controls .ant-input-search-button{color:#1890ff!important}@media (max-width: 768px){.search-bar{flex-direction:column;align-items:stretch}.gallery-stats{text-align:center}.gallery-image{height:180px;object-fit:contain}.image-meta{flex-direction:column;gap:4px}.image-card .ant-card-cover{min-height:180px;height:180px}}.mobile-search-page{padding:12px}.upload-options{display:flex;flex-direction:column;gap:16px}.camera-container{display:flex;flex-direction:column;gap:16px;align-items:center}.webcam-video{width:100%;max-width:400px;height:auto;border-radius:8px;object-fit:cover}.camera-controls{display:flex;flex-direction:column;gap:12px;width:100%}.image-preview-container{display:flex;flex-direction:column;gap:16px;align-items:center}.preview-image{width:100%;max-width:400px;height:auto;object-fit:cover;border-radius:8px}.image-actions{display:flex;flex-direction:column;gap:12px;width:100%}.loading-spinner{text-align:center;margin-top:24px}.results-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width: 420px){.results-grid{grid-template-columns:1fr}}.result-cover{width:100%;height:160px;display:flex;align-items:center;justify-content:center;background-color:#f5f5f5;border-radius:6px;overflow:hidden;contain:content}.result-image{max-width:100%;max-height:100%;object-fit:contain;display:block;will-change:transform}.result-cover .ant-image{width:100%;height:100%;display:block}.result-cover .ant-image-img{width:100%;height:100%;object-fit:contain;display:block}.similarity-badge{position:absolute;top:8px;right:8px;background:#000000b3;color:#fff;padding:2px 6px;border-radius:4px;font-size:12px}.mobile-gallery-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width: 420px){.mobile-gallery-grid{grid-template-columns:1fr}}.empty-results{margin-top:32px}.dashboard-layout{min-height:100vh}.dashboard-header{background:linear-gradient(135deg,#667eea,#764ba2);padding:0 24px;box-shadow:0 2px 8px #0000001a}.header-content{display:flex;justify-content:space-between;align-items:center;height:100%}.header-right{margin-left:auto;display:flex;align-items:center;gap:12px}.header-title{color:#fff;margin:0;font-size:20px;font-weight:700}.logout-button{color:#fff;border:none;background:transparent}.logout-button:hover{background:#ffffff1a;color:#fff}.dashboard-sider{background:#fff;box-shadow:2px 0 8px #0000001a}.dashboard-menu{border-right:none;height:100%}.dashboard-content{background:#f5f5f5;min-height:calc(100vh - 64px)}.content-wrapper{padding:24px;min-height:100%}@media (max-width: 768px){.dashboard-sider{position:fixed;height:100vh;z-index:999;left:0;top:0}.content-wrapper{padding:12px}.header-title{font-size:16px}}.dashboard-layout .dashboard-sider{background:#fff;border-right:1px solid #f0f0f0}.dashboard-layout.mobile-mode .dashboard-content{margin-left:0!important}.dashboard-layout .dashboard-menu{height:100%}.welcome-container{display:flex;justify-content:center;align-items:center;height:100vh;background:#f0f2f5}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Helvetica Neue,Helvetica,Arial,sans-serif;background-color:#f5f5f5;color:#333}.app-container{min-height:100vh}.layout-header{background:linear-gradient(135deg,#667eea,#764ba2);padding:0 24px;box-shadow:0 2px 8px #0000001a}.layout-content{padding:24px;min-height:calc(100vh - 64px)}.search-card{margin-bottom:24px;border-radius:12px;box-shadow:0 4px 12px #0000001a}.upload-area{border:2px dashed #d9d9d9;border-radius:12px;padding:40px;text-align:center;transition:all .3s;cursor:pointer}.upload-area:hover{border-color:#1890ff;background-color:#f0f8ff}.upload-area.dragover{border-color:#1890ff;background-color:#e6f7ff}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-top:16px}.image-card{border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:transform .3s}.image-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.image-preview{width:100%;height:200px;object-fit:cover}.search-results{margin-top:24px}.result-item{display:flex;align-items:center;padding:12px;border-radius:8px;margin-bottom:8px;background:#fff;box-shadow:0 2px 4px #0000001a}.result-image{width:80px;height:80px;object-fit:cover;border-radius:8px;margin-right:16px}.result-info{flex:1}.similarity-score{color:#52c41a;font-weight:700}@media (max-width: 768px){.layout-content{padding:16px}.image-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.upload-area{padding:24px}}.loading-spinner{display:flex;justify-content:center;align-items:center;height:200px}.empty-state{text-align:center;padding:40px;color:#999}.empty-state-icon{font-size:64px;margin-bottom:16px;opacity:.5}.ant-input:-webkit-autofill,.ant-input:-webkit-autofill:hover,.ant-input:-webkit-autofill:focus,.ant-input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 30px #ffffff inset!important;-webkit-text-fill-color:#000000!important;caret-color:#000!important;transition:background-color 5000s ease-in-out 0s!important}.ant-input-password input:-webkit-autofill,.ant-input-password input:-webkit-autofill:hover,.ant-input-password input:-webkit-autofill:focus,.ant-input-password input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 30px #ffffff inset!important;-webkit-text-fill-color:#000000!important;caret-color:#000!important;transition:background-color 5000s ease-in-out 0s!important}.auth-container .ant-input:-webkit-autofill,.auth-container .ant-input:-webkit-autofill:hover,.auth-container .ant-input:-webkit-autofill:focus,.auth-container .ant-input:-webkit-autofill:active,.auth-modal .ant-input:-webkit-autofill,.auth-modal .ant-input:-webkit-autofill:hover,.auth-modal .ant-input:-webkit-autofill:focus,.auth-modal .ant-input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 30px rgba(255,255,255,.1) inset!important;-webkit-text-fill-color:#ffffff!important;caret-color:#fff!important;transition:background-color 5000s ease-in-out 0s!important}.auth-container .ant-input-password input:-webkit-autofill,.auth-container .ant-input-password input:-webkit-autofill:hover,.auth-container .ant-input-password input:-webkit-autofill:focus,.auth-container .ant-input-password input:-webkit-autofill:active,.auth-modal .ant-input-password input:-webkit-autofill,.auth-modal .ant-input-password input:-webkit-autofill:hover,.auth-modal .ant-input-password input:-webkit-autofill:focus,.auth-modal .ant-input-password input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 30px rgba(255,255,255,.1) inset!important;-webkit-text-fill-color:#ffffff!important;caret-color:#fff!important;transition:background-color 5000s ease-in-out 0s!important}.ant-input{background:#fff!important;border:1px solid #d9d9d9!important;color:#000!important;border-radius:6px!important}.ant-input:focus,.ant-input-focused{border-color:#1890ff!important;box-shadow:0 0 0 2px #1890ff33!important}.ant-input::placeholder{color:#bfbfbf!important}.ant-input-affix-wrapper{background:#fff!important;border:1px solid #d9d9d9!important;border-radius:6px!important}.ant-input-affix-wrapper:hover{border-color:#40a9ff!important}.ant-input-affix-wrapper:focus,.ant-input-affix-wrapper-focused{border-color:#1890ff!important;box-shadow:0 0 0 2px #1890ff33!important}.ant-input-affix-wrapper input{background:transparent!important;color:#000!important}.ant-input-search .ant-input-group .ant-input-affix-wrapper{background:#fff!important;border:1px solid #d9d9d9!important}.ant-input-search .ant-input-group .ant-input-affix-wrapper:hover{border-color:#40a9ff!important}.ant-input-search .ant-input-group .ant-input-affix-wrapper-focused{border-color:#1890ff!important;box-shadow:0 0 0 2px #1890ff33!important}.ant-input-password{background:#fff!important;border:1px solid #d9d9d9!important;border-radius:6px!important}.ant-input-password:hover{border-color:#40a9ff!important}.ant-input-password:focus,.ant-input-password-focused{border-color:#1890ff!important;box-shadow:0 0 0 2px #1890ff33!important}.ant-input-password input{background:transparent!important;color:#000!important}.ant-select .ant-select-selector{background:#fff!important;border:1px solid #d9d9d9!important;border-radius:6px!important;color:#000!important}.ant-select:hover .ant-select-selector{border-color:#40a9ff!important}.ant-select-focused .ant-select-selector,.ant-select-focused:hover .ant-select-selector{border-color:#1890ff!important;box-shadow:0 0 0 2px #1890ff33!important}.ant-select .ant-select-selection-placeholder{color:#bfbfbf!important}.ant-select .ant-select-selection-item{color:#000!important}.ant-input.ant-input{background:#fff!important;border:1px solid #d9d9d9!important;color:#000!important;border-radius:6px!important}.ant-input:hover{border-color:#40a9ff!important}.ant-input:focus{border-color:#1890ff!important;box-shadow:0 0 0 2px #1890ff33!important}
