*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #4CAF50;--primary-dark: #388E3C;--primary-light: #A5D6A7;--secondary-color: #2196F3;--secondary-dark: #1976D2;--secondary-light: #64b5f6;--accent-color: #FF9800;--accent-dark: #F57C00;--accent-light: #ffb74d;--error-color: #d32f2f;--error-dark: #b71c1c;--error-light: #ef5350;--text-primary: #1a1a1a;--text-secondary: #5f5f5f;--text-light: #8a8a8a;--background-light: #f5f6f8;--background-white: #ffffff;--border-color: #e8eaed;--shadow: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .1);--榕树绿色: #4CAF50;--榕树深绿: #2e7d32;--榕树浅绿: #e8f5e9;--榕树金色: #ffb300;--榕树棕色: #6d4c41;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--content-max: 1120px;--header-height: 56px;--nav-height: 64px;--bp-sm: 480px;--bp-md: 768px;--bp-lg: 1024px;--bp-xl: 1280px}h1{font-size:24px;color:var(--榕树深绿);font-weight:600;margin-bottom:20px;display:flex;align-items:center}h2{font-size:20px;color:var(--text-primary);font-weight:600;margin-bottom:16px;display:flex;align-items:center;padding-bottom:10px;border-bottom:2px solid var(--榕树浅绿)}h3{font-size:16px;color:var(--text-secondary);font-weight:500;margin-bottom:12px;display:flex;align-items:center}@media(max-width:767px){h1{font-size:20px;margin-bottom:16px}h2{font-size:18px;margin-bottom:12px}h3{font-size:14px;margin-bottom:10px}}@media(max-width:480px){h1{font-size:18px}h2{font-size:16px}h3{font-size:13px}}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--background-light);color:var(--text-primary);background-image:linear-gradient(160deg,#f5f6f8,#e8f5e9,#f5f6f8);min-height:100vh;line-height:1.5;font-size:16px}button,input,select,textarea{font-family:inherit;font-size:inherit}.layout{display:flex;flex-direction:column;min-height:100vh}.header{background:linear-gradient(135deg,var(--榕树绿色) 0%,var(--榕树深绿) 100%);color:#fff;padding:var(--space-md) var(--space-lg);box-shadow:var(--shadow-md);position:sticky;top:0;z-index:100}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:var(--content-max);margin:0 auto;width:100%;padding:0 var(--space-sm)}.app-title{font-size:1.25rem;font-weight:700;margin:0;color:#fff;letter-spacing:.02em;display:flex;align-items:center;gap:var(--space-sm)}.menu-toggle{background:none;border:none;color:#fff;font-size:24px;cursor:pointer;padding:8px;border-radius:4px;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.menu-toggle:hover{background-color:#ffffff1a}.menu-icon{display:block;width:24px;height:2px;background-color:#fff;position:relative;transition:all .3s ease}.menu-icon:before,.menu-icon:after{content:"";position:absolute;width:24px;height:2px;background-color:#fff;transition:all .3s ease}.menu-icon:before{top:-8px}.menu-icon:after{top:8px}.menu-toggle.active .menu-icon{background-color:transparent}.menu-toggle.active .menu-icon:before{transform:rotate(45deg);top:0}.menu-toggle.active .menu-icon:after{transform:rotate(-45deg);top:0}.main-content{flex:1;padding:var(--space-lg);padding-bottom:calc(var(--nav-height) + var(--space-lg));max-width:var(--content-max);margin:0 auto;width:100%;box-sizing:border-box}.navbar{position:fixed;bottom:0;left:0;right:0;background:var(--background-white);box-shadow:0 -2px 12px #0000000f;z-index:1000;height:var(--nav-height);display:flex;align-items:center;justify-content:center;max-width:100vw;overflow:hidden}.navbar-content{display:flex;justify-content:space-around;align-items:center;max-width:var(--content-max);margin:0 auto;padding:var(--space-sm) 0;width:100%;box-sizing:border-box}.navbar a{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);text-decoration:none;color:var(--text-secondary);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);transition:color .2s ease,background .2s ease;flex:1;max-width:88px;min-height:52px;justify-content:center;text-align:center;touch-action:manipulation}.navbar a:hover{background-color:var(--榕树浅绿);color:var(--榕树深绿)}.navbar a.active{color:var(--榕树深绿);font-weight:600;background-color:var(--榕树浅绿)}.nav-icon{font-size:1.25rem;line-height:1}.nav-text{font-size:.75rem;font-weight:500;line-height:1.2}@media(max-width:768px){.menu-toggle{display:block}.navbar{position:fixed;bottom:0;left:0;right:0;width:100%;height:60px;display:flex;align-items:center;justify-content:center;z-index:999}.navbar-content{display:flex;justify-content:space-around;align-items:center;width:100%;padding:8px 0}.navbar a{flex:1;max-width:none;min-height:44px;padding:6px 8px;display:flex;flex-direction:column;align-items:center;justify-content:center}.nav-icon{font-size:18px}.nav-text{font-size:11px}.main-content{padding-bottom:70px}.sidebar{position:fixed;top:60px;right:-100%;width:80%;max-width:280px;height:calc(100vh - 60px);background:#fff;box-shadow:-2px 0 10px #0000001a;z-index:1000;transition:right .3s ease;overflow-y:auto}.sidebar.open{right:0}.sidebar-content{padding:20px}.sidebar-nav{display:flex;flex-direction:column;gap:10px}.sidebar-nav a{display:flex;align-items:center;gap:12px;padding:12px 16px;text-decoration:none;color:var(--text-secondary);border-radius:8px;transition:all .3s ease}.sidebar-nav a:hover{background-color:var(--榕树浅绿);color:var(--榕树深绿)}.sidebar-nav a.active{color:var(--榕树绿色);font-weight:600;background-color:var(--榕树浅绿)}.sidebar-nav .nav-icon{font-size:18px;min-width:24px}.sidebar-nav .nav-text{font-size:14px}.page{padding:12px}.page-header{flex-direction:column;align-items:flex-start;gap:10px}.header-buttons{width:100%;flex-direction:column;gap:8px}.header-buttons button{width:100%}.form-group input,.form-group select,.form-group textarea{padding:12px;font-size:14px}.form-group label{font-size:14px}.add-button,.edit-button,.submit-button,.remove-button,.delete-button,.cancel-button{padding:10px 16px;font-size:14px;width:100%}.card,.project-card,.expense-card,.stat-card{padding:16px}.table-container{gap:12px}.table-row-card{padding:12px}.table-row-card .row-item{padding:6px 0}.table-row-card .row-label{font-size:12px}.table-row-card .row-value{font-size:13px}.modal,.reject-modal-content{width:95%;padding:20px}*{max-width:100%;box-sizing:border-box}body{overflow-x:hidden}.navbar{position:fixed!important;bottom:0!important;left:0!important;right:0!important;z-index:999!important}}.page{max-width:var(--content-max);margin:0 auto;position:relative;z-index:1;width:100%;box-sizing:border-box;overflow-x:hidden;padding:0 var(--space-sm)}.layout{position:relative;z-index:1}.auditor-page{width:100%;box-sizing:border-box}@media(max-width:768px){.auditor-page{padding:15px}.tabs{flex-direction:column;gap:8px;border-bottom:none}.tab-button{padding:12px 16px;border-bottom:none;border-radius:8px;background-color:var(--background-light)}.tab-button.active{background-color:var(--榕树浅绿);border-bottom-color:transparent}.audit-stats{grid-template-columns:1fr}.stat-section{padding:16px}.project-header,.expense-header{flex-direction:column;align-items:flex-start;gap:8px}.project-actions,.expense-actions{flex-direction:column;gap:8px}.approve-button,.reject-button{width:100%;padding:10px}.project-members ul{max-height:200px;overflow-y:auto}.expense-image img{max-width:100%;height:auto}}@media(max-width:480px){.auditor-page{padding:12px}.page-header h1{font-size:18px}.audit-summary{padding:16px}.stat-section,.project-card,.expense-card{padding:12px}.project-header h4,.expense-header h4{font-size:16px}.project-goal{font-size:14px}.project-members li{font-size:13px}.expense-amount{font-size:18px}.form-actions{flex-direction:column;gap:8px}.cancel-button,.submit-button{width:100%}.audit-content{min-height:300px}.page{animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.navbar{position:fixed!important;bottom:0!important;left:0!important;right:0!important;z-index:1000!important}}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:1px solid var(--border-color);flex-wrap:wrap;gap:var(--space-md)}.header-buttons{display:flex;gap:12px;align-items:center;flex-shrink:0;justify-content:flex-end;width:100%}.admin-profile-page .header-buttons{gap:10px}.admin-profile-page .header-buttons button{padding:8px 16px;font-size:14px;font-weight:500;border-radius:8px;transition:all .3s ease;box-shadow:var(--shadow)}.admin-profile-page .header-buttons .edit-button{background-color:var(--primary-color);color:#fff;border:none;padding:8px 16px;font-size:14px;font-weight:500;border-radius:8px;transition:all .3s ease;box-shadow:var(--shadow)}.edit-button:hover,.admin-profile-page .header-buttons .edit-button:hover{background-color:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.admin-profile-page .header-buttons .logout-button{background-color:var(--error-color);color:#fff;border:none;margin-left:0}.admin-profile-page .header-buttons .logout-button:hover{background-color:var(--error-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.settings-button{padding:8px 16px;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;box-shadow:var(--shadow);background-color:var(--secondary-color);color:#fff}.settings-button:hover{background-color:var(--secondary-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.logout-button{padding:8px 16px;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;box-shadow:var(--shadow);background-color:var(--error-color);color:#fff;margin-left:10px}.logout-button:hover{background-color:var(--error-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.profile-header-actions{display:flex;gap:12px;align-items:center;flex-shrink:0;flex-wrap:wrap}.profile-action-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:48px;min-width:48px;padding:10px 16px;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background-color .2s ease;box-shadow:var(--shadow)}.profile-action-btn .profile-action-icon{font-size:1.1rem;line-height:1;display:flex;align-items:center;justify-content:center}.profile-action-btn .profile-action-icon svg{width:18px;height:18px}.profile-action-btn .profile-action-text{white-space:nowrap}.profile-action-btn.edit-profile-btn{background-color:var(--primary-color);color:#fff}.profile-action-btn.edit-profile-btn:hover{background-color:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.profile-action-btn.edit-profile-btn:active{transform:translateY(0);box-shadow:var(--shadow)}.profile-action-btn.logout-btn{background-color:var(--error-color);color:#fff}.profile-action-btn.logout-btn:hover{background-color:var(--error-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.profile-action-btn.logout-btn:active{transform:translateY(0);box-shadow:var(--shadow)}@media(max-width:767px){.profile-header-actions{flex-direction:column;width:100%;gap:10px}.profile-header-actions .profile-action-btn{width:100%;min-width:unset;justify-content:center}.page-header.profile-header-with-actions{align-items:stretch}}.settings-actions{margin-top:30px;display:flex;justify-content:center;gap:10px;padding-top:20px;border-top:1px solid var(--border-color)}.settings-actions button{padding:10px 20px;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;box-shadow:var(--shadow)}.settings-actions .submit-button{background-color:var(--primary-color);color:#fff}.settings-actions .submit-button:hover{background-color:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.page-header h1{font-size:24px;color:#333}.add-button,.edit-button,.submit-button,.add-member-button,.remove-button,.cancel-button,.delete-button{padding:8px 16px;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;box-shadow:var(--shadow)}.add-button,.submit-button,.add-member-button{background-color:var(--primary-color);color:#fff;padding:8px 16px;font-size:14px;font-weight:500;border-radius:8px;transition:all .3s ease;box-shadow:var(--shadow)}.edit-button{background-color:var(--primary-color);color:#fff;padding:8px 16px;font-size:14px;font-weight:500;border-radius:8px;transition:all .3s ease;box-shadow:var(--shadow);width:auto;max-width:120px}.add-button:hover,.edit-button:hover,.submit-button:hover,.add-member-button:hover{background-color:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.remove-button,.delete-button{background-color:var(--error-color);color:#fff;margin-left:10px}.remove-button:hover,.delete-button:hover{background-color:var(--error-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.cancel-button{background-color:var(--text-secondary);color:#fff;margin-right:10px}.add-project-form,.add-expense-form,.profile-form{background-color:var(--background-white);padding:24px;border-radius:12px;box-shadow:var(--shadow-lg);margin-bottom:24px;border-top:4px solid var(--primary-color)}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:var(--text-secondary);font-size:14px}.required{color:var(--error-color);font-weight:700}.optional,.field-hint{color:var(--text-light);font-size:12px;font-weight:400}.form-hint{font-size:12px;color:var(--text-light);margin-top:4px;margin-bottom:0}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:2px solid var(--border-color);border-radius:8px;font-size:14px;transition:all .3s ease;background-color:var(--background-white)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4caf501a}.form-group textarea{resize:vertical;min-height:100px}.error-message{background-color:#f443361a;color:var(--error-color);padding:12px;border-radius:8px;margin-bottom:16px;border-left:4px solid var(--error-color)}.member-item{display:flex;flex-direction:column;gap:10px;margin-bottom:20px;padding:16px;background-color:#00000005;border-radius:8px;border:1px solid var(--border-color)}.member-role{display:flex;align-items:center;gap:10px}.leader-badge{background-color:var(--primary-color);color:#fff;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500}.user-selector{display:flex;flex-direction:column;gap:8px}.user-selector input,.member-item input{width:100%}.project-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.project-actions{display:flex;gap:10px}.leader-tag{background-color:var(--primary-color);color:#fff;padding:2px 6px;border-radius:8px;font-size:12px;font-weight:500;margin-right:8px}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal{background-color:var(--background-white);padding:24px;border-radius:12px;box-shadow:var(--shadow-lg);max-width:400px;width:90%}.modal h3{margin-bottom:16px;color:var(--text-primary)}.modal p{margin-bottom:16px;color:var(--text-secondary)}.verification{margin-bottom:16px}.verification input{width:100%;padding:12px;border:2px solid var(--border-color);border-radius:8px;margin-top:8px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.expense-category{margin-bottom:12px}.category-tag{background-color:var(--secondary-color);color:#fff;padding:4px 12px;border-radius:16px;font-size:12px;font-weight:500}.card,.project-card,.expense-card,.stat-card,.project-stat-item,.expense-stat-item{background-color:var(--background-white);padding:24px;border-radius:12px;box-shadow:var(--shadow);margin-bottom:20px;transition:all .3s ease;border:1px solid var(--border-color)}.card:hover,.project-card:hover,.expense-card:hover,.stat-card:hover,.project-stat-item:hover,.expense-stat-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.home-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px;margin-top:20px}.card{position:relative;overflow:hidden}.card:nth-child(1){border-top:4px solid var(--primary-color)}.card:nth-child(2){border-top:4px solid var(--secondary-color)}.card:nth-child(3){border-top:4px solid var(--accent-color)}.card:nth-child(4){border-top:4px solid var(--error-color)}.card h2{font-size:20px;margin-bottom:12px;color:var(--text-primary);font-weight:600}.card p{color:var(--text-secondary);line-height:1.5}.card:after{content:"";position:absolute;bottom:0;right:0;width:80px;height:80px;background-color:#0000000d;border-radius:50% 0 0;z-index:0}.projects-list,.expenses-list{margin-top:24px}.project-card h3{font-size:20px;margin-bottom:12px;color:var(--text-primary);font-weight:600;display:flex;align-items:center}.project-card h3:before{content:"📁";margin-right:10px;font-size:18px}.project-goal{margin-bottom:16px;color:var(--text-secondary);line-height:1.5;padding:12px;background-color:#4caf500d;border-radius:8px;border-left:4px solid var(--primary-color)}.project-members h4{font-size:16px;margin-bottom:8px;color:var(--text-secondary);font-weight:500}.project-members ul{list-style:none;padding-left:0}.project-members li{padding:10px 12px;border-bottom:1px solid var(--border-color);border-radius:6px;margin-bottom:8px;background-color:#00000005;transition:all .2s ease}.project-members li:hover{background-color:#0000000d;transform:translate(4px)}.expense-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--border-color)}.expense-header h3{font-size:18px;color:var(--text-primary);font-weight:600;display:flex;align-items:center}.expense-header h3:before{content:"💰";margin-right:10px;font-size:16px}.expense-amount{font-weight:700;color:var(--error-color);font-size:18px;padding:6px 12px;background-color:#f443361a;border-radius:20px}.expense-project,.expense-note,.expense-date{margin-bottom:12px;color:var(--text-secondary);font-size:14px;line-height:1.4}.expense-project{display:flex;align-items:center}.expense-project:before{content:"📁";margin-right:8px;font-size:14px}.expense-note{padding:12px;background-color:#2196f30d;border-radius:8px;border-left:4px solid var(--secondary-color)}.expense-date{font-size:12px;color:var(--text-light);font-style:italic}.expense-reviewed{font-size:12px;color:var(--text-light);font-style:italic;margin-top:8px}.expense-rejection-reason{margin:12px 0;color:var(--error-color);font-weight:700;padding:12px;background-color:#f443361a;border-radius:8px;border-left:4px solid var(--error-color);font-size:14px}.status-badge{padding:4px 12px;border-radius:16px;font-size:12px;font-weight:600;display:inline-block;margin-left:10px}.expense-actions{display:flex;gap:10px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border-color)}.approve-button{background-color:var(--primary-color);color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;box-shadow:var(--shadow)}.reject-button{background-color:var(--error-color);color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;box-shadow:var(--shadow);margin-left:0}.resubmit-button{background-color:var(--secondary-color);color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;box-shadow:var(--shadow)}.resubmit-button:hover{background-color:var(--secondary-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.reject-form{background-color:var(--background-white);padding:24px;border-radius:12px;box-shadow:var(--shadow-lg);margin:24px 0;border-top:4px solid var(--error-color)}.reject-form h3{margin-top:0;color:var(--text-primary);font-size:18px;font-weight:600;margin-bottom:16px}.reject-form .form-actions{display:flex;gap:10px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border-color);justify-content:flex-end}.cancel-button{background-color:var(--text-secondary);color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;box-shadow:var(--shadow);margin-right:0}.cancel-button:hover{background-color:var(--text-primary);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.reject-modal{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.reject-modal-content{background-color:var(--background-white);padding:24px;border-radius:12px;box-shadow:var(--shadow-lg);max-width:400px;width:90%;border-top:4px solid var(--error-color)}.reject-modal-content h2{margin-top:0;color:var(--text-primary);font-size:18px;font-weight:600;margin-bottom:16px}.reject-modal-content .form-actions{display:flex;gap:10px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border-color);justify-content:flex-end}.submit-message{background-color:#4caf501a;color:var(--primary-color);border:1px solid rgba(76,175,80,.3);border-radius:8px;padding:16px;margin:16px 0;font-weight:700;font-size:14px;display:flex;align-items:center;gap:10px}.submit-message:before{content:"✅";font-size:18px}.tag-list{margin-top:16px;display:flex;flex-direction:column;gap:12px}.tag-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background-color:#00000005;border-radius:8px;border:1px solid var(--border-color);transition:all .3s ease}.tag-item:hover{background-color:#0000000d;transform:translateY(-2px);box-shadow:var(--shadow)}.tag-name{font-weight:500;color:var(--text-primary);flex:1}.tag-name.active{color:var(--primary-color)}.tag-name.inactive{color:var(--text-light);text-decoration:line-through}.tag-status{font-size:12px;padding:4px 8px;border-radius:12px;margin:0 12px}.tag-status.active{background-color:#4caf501a;color:var(--primary-color);border:1px solid rgba(76,175,80,.3)}.tag-status.inactive{background-color:#9e9e9e1a;color:var(--text-light);border:1px solid rgba(158,158,158,.3)}.tag-action-button{padding:6px 12px;border:none;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow)}.tag-action-button.activate{background-color:var(--primary-color);color:#fff}.tag-action-button.activate:hover{background-color:var(--primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-lg)}.tag-action-button.deactivate{background-color:var(--error-color);color:#fff}.tag-action-button.deactivate:hover{background-color:var(--error-dark);transform:translateY(-1px);box-shadow:var(--shadow-lg)}.success-message{background-color:#4caf501a;color:var(--primary-color);border:1px solid rgba(76,175,80,.3);border-radius:8px;padding:12px;margin-bottom:16px;font-weight:500}.error-message{background-color:#f443361a;color:var(--error-color);border:1px solid rgba(244,67,54,.3);border-radius:8px;padding:12px;margin-bottom:16px;font-weight:500}.expense-image img{max-width:100%;max-height:200px;border-radius:8px;margin-bottom:12px;box-shadow:var(--shadow);transition:transform .3s ease}.expense-image img:hover{transform:scale(1.02)}.finance-settings{background-color:var(--background-white);padding:24px;border-radius:12px;box-shadow:var(--shadow-lg);margin-bottom:24px;border-top:4px solid var(--secondary-color)}.finance-settings h2{font-size:20px;margin-bottom:20px;color:var(--text-primary);font-weight:600}.settings-section{margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid var(--border-color)}.settings-section:last-child{border-bottom:none}.settings-section h3{font-size:16px;margin-bottom:15px;color:var(--text-secondary);font-weight:500}.settings-form{background-color:#00000005;padding:20px;border-radius:8px;margin-bottom:15px}.settings-list{margin-top:15px}.settings-list h4{font-size:14px;margin-bottom:10px;color:var(--text-secondary);font-weight:500}.settings-list ul{list-style:none;padding-left:0}.settings-list li{padding:8px 12px;border-bottom:1px solid var(--border-color);border-radius:6px;margin-bottom:6px;background-color:#00000005;transition:all .2s ease}.settings-list li:hover{background-color:#0000000d;transform:translate(4px)}.preview-image img{max-width:100px;max-height:100px;border-radius:4px;margin-top:10px}.stats-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px;margin-bottom:32px;margin-top:24px}.stat-card{text-align:center;position:relative;overflow:hidden}.stat-card:nth-child(1){border-top:4px solid var(--primary-color)}.stat-card:nth-child(2){border-top:4px solid var(--secondary-color)}.stat-card h2{font-size:16px;color:var(--text-secondary);margin-bottom:12px;font-weight:500}.stat-value{font-size:36px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.stat-card:after{content:"";position:absolute;top:0;right:0;width:60px;height:60px;background-color:#0000000d;border-radius:0 0 0 50%;z-index:0}.project-stats,.expense-stats{margin-top:32px}.project-stats h2,.expense-stats h2{font-size:20px;margin-bottom:20px;color:var(--text-primary);font-weight:600;display:flex;align-items:center}.project-stats h2:before{content:"📊";margin-right:10px;font-size:18px}.expense-stats h2:before{content:"💰";margin-right:10px;font-size:18px}.project-stat-item h3{font-size:18px;margin-bottom:12px;color:var(--text-primary);font-weight:600;display:flex;align-items:center}.project-stat-item h3:before{content:"📁";margin-right:10px;font-size:16px}.project-expense,.project-members{color:var(--text-secondary);font-size:14px;margin-bottom:8px;display:flex;align-items:center}.project-expense:before{content:"💸";margin-right:8px;font-size:14px}.project-members:before{content:"👥";margin-right:8px;font-size:14px}.expense-stat-item{display:flex;flex-direction:column;gap:8px;padding:16px}.expense-info{display:flex;justify-content:space-between;align-items:center}.expense-item{font-weight:500;color:var(--text-primary);display:flex;align-items:center}.expense-item:before{content:"📝";margin-right:8px;font-size:14px}.expense-project-small{font-size:12px;color:var(--text-light);display:flex;align-items:center}.expense-project-small:before{content:"📁";margin-right:6px;font-size:12px}.more-expenses{text-align:center;color:var(--text-secondary);margin-top:16px;font-style:italic;padding:12px;background-color:#0000000d;border-radius:8px}.profile-header{text-align:center;margin-bottom:30px}.avatar-container{width:120px;height:120px;border-radius:50%;overflow:hidden;margin:0 auto 20px;box-shadow:0 4px 12px #00000026;border:3px solid var(--primary-color)}.profile-avatar{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;display:flex;justify-content:center;align-items:center;background-color:var(--primary-light);color:#fff;font-size:48px;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.2)}.profile-header h2{font-size:24px;margin-bottom:8px;color:var(--text-primary)}.profile-header p{color:var(--text-secondary);font-size:16px;margin:0}.avatar-upload{display:flex;flex-direction:column;align-items:center;gap:12px}.avatar-preview{width:100px;height:100px;border-radius:50%;overflow:hidden;border:2px solid var(--border-color);box-shadow:var(--shadow)}.avatar-placeholder{width:100%;height:100%;display:flex;justify-content:center;align-items:center;background-color:var(--background-light);color:var(--text-secondary);font-size:12px;text-align:center;padding:10px;box-sizing:border-box}.avatar-label{background-color:var(--primary-color);color:#fff;padding:8px 16px;border-radius:20px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow)}.avatar-label:hover{background-color:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.profile-info{background-color:var(--background-white);padding:24px;border-radius:12px;box-shadow:var(--shadow-lg);border-top:4px solid var(--accent-color);margin-top:24px}.info-item{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--border-color);transition:all .2s ease}.info-item:hover{background-color:#00000005;padding-left:12px;border-left:4px solid var(--accent-color);border-radius:0 8px 8px 0}.info-item label{display:block;font-weight:500;color:var(--text-secondary);margin-bottom:8px;font-size:14px;display:flex;align-items:center}.info-item label:before{content:"👤";margin-right:10px;font-size:16px}.info-item:nth-child(3) label:before{content:"🏷️"}.info-item span,.info-item p{color:var(--text-primary);line-height:1.5;padding:8px 12px;background-color:#00000005;border-radius:6px;margin-top:4px}.info-item p{line-height:1.6;white-space:pre-wrap}.profile-page{max-width:1200px;margin:0 auto;padding:0 15px}.profile-completion-banner{margin-bottom:20px;padding:16px 20px;background:linear-gradient(135deg,#2e7d321f,#4caf5014);border:1px solid rgba(76,175,80,.35);border-radius:12px;border-left:4px solid var(--primary-color, #2e7d32)}.profile-completion-content strong{display:block;margin-bottom:6px;color:var(--text-primary, #333)}.profile-completion-content p{margin:0 0 12px;font-size:14px;color:var(--text-secondary, #555);line-height:1.5}.profile-completion-actions{display:flex;align-items:center;gap:12px}.profile-completion-cta{padding:8px 16px;background:var(--primary-color, #2e7d32);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;font-size:14px}.profile-completion-cta:hover{background:var(--榕树深绿, #1b5e20)}.profile-completion-dismiss{background:none;border:none;color:#666;cursor:pointer;font-size:20px;line-height:1;padding:0 4px}.profile-header{text-align:center;margin-bottom:30px;padding:30px 0;background:linear-gradient(135deg,var(--background-white) 0%,var(--榕树浅绿) 100%);border-radius:16px;box-shadow:var(--shadow-lg);margin-top:20px;position:relative;overflow:hidden;border:1px solid var(--榕树浅绿)}.profile-header:before{content:"";position:absolute;top:-50%;right:-50%;width:200px;height:200px;background-color:#4caf501a;border-radius:50%;z-index:0}.avatar-container{width:120px;height:120px;border-radius:50%;overflow:hidden;margin:0 auto 20px;box-shadow:0 4px 16px #0003;border:4px solid white;position:relative;z-index:1;transition:all .3s ease}.avatar-container:hover{transform:scale(1.05);box-shadow:0 6px 20px #00000040}.profile-avatar{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.avatar-container:hover .profile-avatar{transform:scale(1.1)}.avatar-placeholder{width:100%;height:100%;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);color:#fff;font-size:48px;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.3);transition:all .3s ease}.avatar-container:hover .avatar-placeholder{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary-color) 100%)}.profile-header h2{font-size:24px;margin-bottom:8px;color:var(--text-primary);font-weight:600;position:relative;z-index:1}.profile-header .profile-name{text-align:center;width:100%}.profile-role-text{margin:0;color:var(--text-secondary);font-size:14px}.profile-header p{color:var(--text-secondary);font-size:16px;margin:0;position:relative;z-index:1;font-weight:500}.avatar-upload{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:24px}.avatar-preview{width:120px;height:120px;border-radius:50%;overflow:hidden;border:3px solid var(--primary-light);box-shadow:var(--shadow-lg);transition:all .3s ease}.avatar-preview:hover{transform:scale(1.05);box-shadow:var(--shadow-lg);border-color:var(--primary-color)}.avatar-preview img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,var(--background-light) 0%,var(--primary-light) 100%);color:var(--text-secondary);font-size:14px;text-align:center;padding:10px;box-sizing:border-box;transition:all .3s ease}.avatar-label{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);color:#fff;padding:10px 20px;border-radius:25px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow);border:none;outline:none}.avatar-label:hover{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary-color) 100%);transform:translateY(-3px);box-shadow:var(--shadow-lg)}.profile-info{background:linear-gradient(135deg,var(--background-white) 0%,#f8fff8 100%);padding:24px;border-radius:16px;box-shadow:var(--shadow-lg);border:1px solid var(--榕树浅绿);margin-top:24px;position:relative;overflow:hidden}.profile-info:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(to bottom,var(--榕树绿色),var(--榕树深绿));border-radius:16px 0 0 16px}.info-item{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--榕树浅绿);transition:all .3s ease;position:relative;z-index:1}.info-item:hover{background-color:#4caf500d;padding-left:16px;border-left:4px solid var(--榕树绿色);border-radius:0 8px 8px 0;transform:translate(4px)}.info-item:last-child{border-bottom:none}.info-item label{display:block;font-weight:500;color:var(--text-secondary);margin-bottom:8px;font-size:14px;display:flex;align-items:center;transition:color .3s ease}.info-item:hover label{color:var(--榕树深绿)}.info-item label:before{content:"👤";margin-right:10px;font-size:18px;transition:transform .3s ease}.info-item:hover label:before{transform:scale(1.1)}.info-item:nth-child(1) label:before{content:"👨‍💼"}.info-item:nth-child(2) label:before{content:"🔒"}.info-item:nth-child(3) label:before{content:"🏢"}.info-item:nth-child(4) label:before{content:"✅"}.info-item:nth-child(5) label:before{content:"❌"}.info-item:nth-child(6) label:before{content:"📝"}.info-item span,.info-item p{color:var(--text-primary);line-height:1.5;padding:10px 16px;background-color:#fffc;border-radius:8px;margin-top:4px;border:1px solid var(--榕树浅绿);transition:all .3s ease;font-weight:500}.info-item:hover span,.info-item:hover p{background-color:#fff;border-color:var(--榕树绿色);box-shadow:var(--shadow)}.info-item p{line-height:1.6;white-space:pre-wrap;min-height:60px;display:flex;align-items:center}.profile-stats{margin-top:30px;margin-bottom:30px}.profile-stats h2{font-size:20px;margin-bottom:20px;color:var(--榕树深绿);font-weight:600;display:flex;align-items:center;padding-bottom:12px;border-bottom:2px solid var(--榕树浅绿)}.profile-stats h2:before{content:"📊";margin-right:10px;font-size:18px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.stats-grid .stat-card{background:linear-gradient(135deg,#fff,#f8fff8);padding:24px;border-radius:16px;box-shadow:var(--shadow);text-align:center;transition:all .3s ease;border:1px solid var(--榕树浅绿);position:relative;overflow:hidden}.stats-grid .stat-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--榕树绿色)}.stats-grid .stat-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(to bottom,var(--榕树绿色),var(--榕树深绿));border-radius:16px 0 0 16px}.stats-grid .stat-card:after{content:"";position:absolute;bottom:-10px;right:-10px;width:80px;height:80px;background-color:var(--榕树浅绿);border-radius:50%;opacity:.2;z-index:0}.stats-grid .stat-card h3{font-size:16px;color:var(--text-secondary);margin-bottom:12px;font-weight:500;display:flex;align-items:center;justify-content:center;position:relative;z-index:1}.stats-grid .stat-card h3:before{content:"📈";margin-right:8px;font-size:18px}.stats-grid .stat-card:nth-child(1) h3:before{content:"📁"}.stats-grid .stat-card:nth-child(2) h3:before{content:"👑"}.stats-grid .stat-card:nth-child(3) h3:before{content:"💰"}.stats-grid .stat-card .stat-value{font-size:36px;font-weight:700;color:var(--榕树深绿);margin-bottom:8px;line-height:1;position:relative;z-index:1;transition:all .3s ease}.stats-grid .stat-card:hover .stat-value{transform:scale(1.05)}.login-button{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);color:#fff;padding:12px 24px;border-radius:25px;font-size:16px;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow);border:none;outline:none;margin-top:20px;width:100%;max-width:200px;display:block;margin-left:auto;margin-right:auto}.login-button:hover{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary-color) 100%);transform:translateY(-3px);box-shadow:var(--shadow-lg)}.empty-message{text-align:center;color:#999;padding:40px 0;background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}table{width:100%;border-collapse:collapse;margin:20px 0;background-color:#fff;border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}th,td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border-color)}th{background-color:var(--榕树浅绿);color:var(--榕树深绿);font-weight:600;font-size:14px}tr:hover{background-color:#4caf500d}@media(max-width:768px){table{display:block;overflow-x:auto}th,td{padding:10px 12px;font-size:14px}}@media(max-width:480px){table{display:none}.table-container{display:flex;flex-direction:column;gap:16px}.table-row-card{background-color:#fff;border-radius:12px;box-shadow:var(--shadow);padding:16px;border:1px solid var(--border-color)}.table-row-card .row-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border-color)}.table-row-card .row-item:last-child{border-bottom:none}.table-row-card .row-label{font-weight:600;color:var(--text-secondary);font-size:13px}.table-row-card .row-value{color:var(--text-primary);font-size:14px;font-weight:500}.table-row-card .row-actions{display:flex;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color)}.table-row-card .row-actions button{padding:8px 16px;font-size:13px}}.loading{text-align:center;padding:40px 0;color:var(--text-secondary);font-size:16px}@media(max-width:767px){.profile-page{padding:0 12px}.profile-header{padding:20px 15px;margin-top:15px}.avatar-container{width:100px;height:100px;margin-bottom:16px}.profile-header h2{font-size:20px}.profile-header p{font-size:14px}.profile-info{padding:16px;margin-top:20px}.info-item{margin-bottom:16px;padding-bottom:16px}.info-item:hover{padding-left:12px}.info-item span,.info-item p{padding:8px 12px;font-size:14px}.profile-stats{margin-top:24px;margin-bottom:24px}.profile-stats h2{font-size:18px;margin-bottom:16px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:16px}.stats-grid .stat-card{padding:16px}.stats-grid .stat-card h3{font-size:14px}.stats-grid .stat-card .stat-value{font-size:28px}.login-button{padding:10px 20px;font-size:14px;max-width:180px}}@media(max-width:480px){.profile-header{padding:16px 12px}.avatar-container{width:80px;height:80px;margin-bottom:12px}.profile-header h2{font-size:18px}.profile-header p{font-size:12px}.profile-info{padding:12px}.info-item{margin-bottom:12px;padding-bottom:12px}.info-item label{font-size:12px}.info-item label:before{font-size:14px}.info-item span,.info-item p{padding:6px 10px;font-size:13px}.stats-grid{grid-template-columns:1fr;gap:12px}.stats-grid .stat-card{padding:12px}.stats-grid .stat-card h3{font-size:13px}.stats-grid .stat-card .stat-value{font-size:24px}.login-button{padding:8px 16px;font-size:12px;max-width:150px}}.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px;margin-top:24px}.admin-stats .stat-card{background:linear-gradient(135deg,#fff,#f8fff8);border:1px solid var(--榕树浅绿);border-radius:16px;padding:24px;box-shadow:var(--shadow);transition:all .3s ease;position:relative;overflow:hidden}.admin-stats .stat-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--榕树绿色)}.admin-stats .stat-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(to bottom,var(--榕树绿色),var(--榕树深绿));border-radius:16px 0 0 16px}.admin-stats .stat-card h2{font-size:16px;color:var(--text-secondary);margin-bottom:12px;font-weight:500;display:flex;align-items:center}.admin-stats .stat-card h2:before{content:"📊";margin-right:8px;font-size:18px}.admin-stats .stat-card:nth-child(1) h2:before{content:"📁"}.admin-stats .stat-card:nth-child(2) h2:before{content:"👥"}.admin-stats .stat-card:nth-child(3) h2:before{content:"💰"}.admin-stats .stat-card:nth-child(4) h2:before{content:"💹"}.admin-stats .stat-value{font-size:36px;font-weight:700;color:var(--榕树深绿);margin-bottom:8px;line-height:1}.admin-stats .stat-card:after{content:"";position:absolute;bottom:-10px;right:-10px;width:80px;height:80px;background-color:var(--榕树浅绿);border-radius:50%;opacity:.2;z-index:0}.admin-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-top:30px;margin-bottom:30px}.overview-section{background:linear-gradient(135deg,#fff,#f8fff8);padding:24px;border-radius:16px;box-shadow:var(--shadow);border:1px solid var(--榕树浅绿);transition:all .3s ease}.overview-section:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--榕树绿色)}.overview-section h3{margin-bottom:20px;color:var(--榕树深绿);font-size:18px;font-weight:600;display:flex;align-items:center;padding-bottom:12px;border-bottom:2px solid var(--榕树浅绿)}.overview-section h3:before{content:"📋";margin-right:10px;font-size:18px}.overview-section:nth-child(1) h3:before{content:"📁"}.overview-section:nth-child(2) h3:before{content:"💰"}.overview-item{padding:16px;border-bottom:1px solid var(--榕树浅绿);margin-bottom:16px;border-radius:8px;transition:all .3s ease;background-color:#ffffffb3}.overview-item:hover{background-color:#fff;transform:translate(4px);box-shadow:var(--shadow)}.overview-item:last-child{border-bottom:none;margin-bottom:0}.overview-item h4{margin-bottom:8px;color:var(--text-primary);font-size:16px;font-weight:600}.overview-item p{color:var(--text-secondary);font-size:14px;display:flex;align-items:center}.overview-item p:before{content:"📌";margin-right:8px;font-size:14px}.overview-section:nth-child(1) .overview-item p:before{content:"👥"}.overview-section:nth-child(2) .overview-item p:before{content:"💸"}.add-staff-form{background-color:var(--background-white);padding:24px;border-radius:12px;box-shadow:var(--shadow-lg);margin-bottom:24px;border-top:4px solid var(--primary-color)}.add-staff-form.delete-confirm-inline{margin-top:12px;margin-bottom:0;border-top-width:2px}.checkbox-group{margin-bottom:20px}.checkboxes{display:flex;gap:20px;margin-top:8px}.checkboxes label{display:flex;align-items:center;gap:8px;font-weight:400;color:var(--text-secondary)}.checkbox-item{position:relative;display:flex;align-items:center;cursor:pointer;font-size:14px;-webkit-user-select:none;user-select:none}.checkbox-item input[type=checkbox]{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.checkbox-item .checkbox-custom{position:relative;height:20px;width:20px;background-color:#f8f9fa;border:2px solid var(--border-color);border-radius:4px;transition:all .3s ease}.checkbox-item:hover .checkbox-custom{border-color:var(--primary-color);background-color:#e8f5e8}.checkbox-item input[type=checkbox]:checked~.checkbox-custom{background-color:var(--primary-color);border-color:var(--primary-color)}.checkbox-item .checkbox-custom:after{content:"";position:absolute;display:none;left:6px;top:2px;width:6px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.checkbox-item input[type=checkbox]:checked~.checkbox-custom:after{display:block}.checkbox-item .checkbox-label{margin-left:28px;transition:color .3s ease}.checkbox-item input[type=checkbox]:checked~.checkbox-label{color:var(--primary-color);font-weight:500}@media(max-width:767px){.checkboxes{flex-direction:column;gap:12px}.checkbox-item{font-size:13px}.checkbox-item .checkbox-custom{height:18px;width:18px}.checkbox-item .checkbox-custom:after{left:5px;top:1px;width:5px;height:9px}.checkbox-item .checkbox-label{margin-left:24px}}@media(max-width:480px){.checkbox-item{font-size:12px}.checkbox-item .checkbox-custom{height:16px;width:16px}.checkbox-item .checkbox-custom:after{left:4px;top:1px;width:4px;height:8px}.checkbox-item .checkbox-label{margin-left:22px}}.staff-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.staff-card{background-color:var(--background-white);padding:20px;border-radius:8px;box-shadow:var(--shadow);transition:all .3s ease;font-size:14px}.staff-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.staff-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.staff-header h3{color:var(--text-primary);font-size:16px}.user-code{background-color:var(--primary-light);color:var(--primary-dark);padding:4px 8px;border-radius:8px;font-size:12px;font-weight:500}.staff-username{margin-bottom:10px;color:var(--text-secondary)}.staff-strengths,.staff-weaknesses,.staff-bio{margin-bottom:8px;color:var(--text-secondary);font-size:14px;line-height:1.4}.staff-roles{margin-top:15px;display:flex;gap:10px;flex-wrap:wrap}.role-tag{padding:4px 12px;border-radius:16px;font-size:12px;font-weight:500}.finance-tag{background-color:#2196f31a;color:var(--secondary-color)}.auditor-tag{background-color:#ff98001a;color:var(--accent-color)}.finance-summary{background:linear-gradient(135deg,#fff,#f8fff8);padding:24px;border-radius:16px;box-shadow:var(--shadow);margin-bottom:24px;border:1px solid var(--榕树浅绿);transition:all .3s ease}.finance-summary:hover{box-shadow:var(--shadow-lg);border-color:var(--榕树绿色)}.finance-summary h2{font-size:20px;margin-bottom:20px;color:var(--榕树深绿);font-weight:600;display:flex;align-items:center;padding-bottom:12px;border-bottom:2px solid var(--榕树浅绿)}.finance-summary h2:before{content:"💰";margin-right:10px;font-size:20px}.finance-summary p{margin-bottom:12px;color:var(--text-secondary);font-size:14px;line-height:1.5;display:flex;align-items:center}.finance-summary p:before{content:"📌";margin-right:8px;font-size:14px}.download-buttons{margin-top:20px;display:flex;gap:12px;flex-wrap:wrap;padding-top:16px;border-top:1px solid var(--榕树浅绿)}.download-button{padding:10px 16px;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;box-shadow:var(--shadow);background-color:var(--榕树绿色);color:#fff;display:flex;align-items:center}.download-button:hover{background-color:var(--榕树深绿);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.download-button:before{content:"📥";margin-right:8px;font-size:14px}.finance-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-bottom:30px}.stat-section{background:linear-gradient(135deg,#fff,#f8fff8);padding:24px;border-radius:16px;box-shadow:var(--shadow);border:1px solid var(--榕树浅绿);transition:all .3s ease}.stat-section:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--榕树绿色)}.stat-section h3{margin-bottom:20px;color:var(--榕树深绿);font-size:18px;font-weight:600;display:flex;align-items:center;padding-bottom:12px;border-bottom:2px solid var(--榕树浅绿)}.stat-section h3:before{content:"📊";margin-right:10px;font-size:18px}.stat-section:nth-child(1) h3:before{content:"🏷️"}.stat-section:nth-child(2) h3:before{content:"📁"}.stat-section:nth-child(3) h3:before{content:"👥"}.stat-section:nth-child(4) h3:before{content:"📦"}.category-stats,.project-stats,.customer-stats,.product-stats{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.category-item,.project-item,.customer-item,.product-item{display:flex;justify-content:space-between;padding:12px 16px;background-color:#ffffffb3;border-radius:8px;transition:all .3s ease;border:1px solid var(--榕树浅绿)}.category-item:hover,.project-item:hover,.customer-item:hover,.product-item:hover{background-color:#fff;transform:translate(4px);box-shadow:var(--shadow);border-color:var(--榕树绿色)}.category-name,.project-name,.customer-name,.product-name{color:var(--text-primary);font-weight:500;flex:1}.category-amount,.project-amount,.customer-amount,.product-amount{color:var(--榕树深绿);font-weight:600;font-size:14px;padding:4px 8px;background-color:var(--榕树浅绿);border-radius:12px;min-width:80px;text-align:right}.expenses-tabs{margin-top:30px;margin-bottom:30px}.expenses-tabs h3{font-size:18px;margin-bottom:20px;color:var(--榕树深绿);font-weight:600;display:flex;align-items:center;padding-bottom:12px;border-bottom:2px solid var(--榕树浅绿);margin-top:30px}.expenses-tabs h3:before{content:"💰";margin-right:10px;font-size:18px}.expenses-tabs h3:nth-of-type(1):before{content:"⏳"}.expenses-tabs h3:nth-of-type(2):before{content:"✅"}.expenses-tabs h3:nth-of-type(3):before{content:"❌"}.projects-summary{background:linear-gradient(135deg,#fff,#f5fbf7);padding:20px 24px;border-radius:18px;box-shadow:var(--shadow-md);margin:24px 0;border:1px solid var(--榕树浅绿);transition:all .3s ease;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.projects-summary:hover{box-shadow:var(--shadow-lg);border-color:var(--榕树绿色)}.projects-summary h2{margin-bottom:12px;color:var(--榕树深绿);font-size:18px;font-weight:600;display:flex;align-items:center;padding-bottom:12px;border-bottom:2px solid var(--榕树浅绿)}.projects-summary h2:before{content:"📁";margin-right:10px;font-size:18px}.projects-summary p{color:var(--text-secondary);font-size:14px;display:flex;align-items:center}.projects-summary p:before{content:"📌";margin-right:8px;font-size:14px}.projects-version-panel{margin-top:8px;text-align:right}.projects-version-panel .version-text{font-size:12px;color:var(--text-light)}.admin-projects-page{display:flex;flex-direction:column;gap:24px}.admin-projects-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:0}.admin-projects-header-copy h1{margin-bottom:8px}.admin-projects-subtitle{color:var(--text-secondary);font-size:14px;line-height:1.6;margin:0}.projects-version-badge{display:inline-flex;align-items:center;padding:8px 14px;border-radius:999px;background:#4caf501a;color:var(--primary-dark);font-size:12px;font-weight:700;white-space:nowrap;border:1px solid rgba(76,175,80,.16)}.admin-projects-summary{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(300px,.95fr);gap:20px}.admin-projects-hero{position:relative;overflow:hidden;padding:28px;border-radius:24px;background:linear-gradient(135deg,var(--primary-dark) 0%,#43a047 56%,#7cb342 100%);color:#fff;box-shadow:var(--shadow-lg)}.admin-projects-hero:before,.admin-projects-hero:after{content:"";position:absolute;border-radius:999px;background:#ffffff1a;pointer-events:none}.admin-projects-hero:before{width:220px;height:220px;top:-110px;right:-60px}.admin-projects-hero:after{width:140px;height:140px;bottom:-50px;right:120px}.hero-eyebrow{display:inline-block;margin-bottom:12px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;opacity:.88}.hero-value{font-size:56px;font-weight:800;line-height:1}.hero-description{margin:12px 0 0;font-size:15px;line-height:1.6;color:#ffffffeb}.hero-status-strip{position:relative;z-index:1;margin-top:26px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.hero-status-item{padding:14px;border-radius:18px;background:#ffffff1f;border:1px solid rgba(255,255,255,.18);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.hero-status-label{display:block;font-size:12px;opacity:.88}.hero-status-value{display:block;margin-top:6px;font-size:22px;line-height:1}.hero-status-percent{display:block;margin-top:6px;font-size:12px;opacity:.82}.admin-projects-side-panels{display:grid;gap:16px}.admin-projects-page .summary-panel{background:#ffffffeb;border:1px solid rgba(255,255,255,.7);border-radius:22px;padding:22px;box-shadow:var(--shadow-md)}.admin-projects-page .summary-panel h2,.admin-projects-page .collection-header h2{margin:0 0 16px;padding:0;border:none;font-size:16px;color:var(--text-primary)}.key-metrics-panel{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.summary-metric{padding:14px 16px;border-radius:16px;background:linear-gradient(180deg,#f8fcf4f5,#e8f5e9d1);border:1px solid rgba(76,175,80,.12)}.summary-label{display:block;color:var(--text-secondary);font-size:12px;line-height:1.5}.summary-value{display:block;margin-top:8px;color:var(--primary-dark);font-size:26px;font-weight:800;line-height:1.1}.status-breakdown{display:flex;flex-direction:column;gap:14px}.status-breakdown-row{display:flex;flex-direction:column;gap:8px}.status-breakdown-head{display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:13px;color:var(--text-secondary)}.status-breakdown-head strong{color:var(--text-primary)}.status-breakdown-track{overflow:hidden;width:100%;height:10px;border-radius:999px;background:#0f172a14}.status-breakdown-fill{height:100%;border-radius:inherit;transition:width .35s ease}.status-breakdown-fill.status-draft,.mini-fill.status-draft{background:linear-gradient(90deg,#ffb74d,#f57c00)}.status-breakdown-fill.status-pending,.mini-fill.status-pending{background:linear-gradient(90deg,#ffe082,#ffb300)}.status-breakdown-fill.status-approved,.mini-fill.status-approved{background:linear-gradient(90deg,#81c784,#388e3c)}.status-breakdown-fill.status-rejected,.mini-fill.status-rejected{background:linear-gradient(90deg,#ef9a9a,#d32f2f)}.panel-empty{color:var(--text-secondary);font-size:14px;line-height:1.6}.panel-empty.compact{margin:0;padding:0}.admin-projects-insights{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}.rank-list{list-style:none;display:flex;flex-direction:column;gap:12px;padding:0;margin:0}.rank-list-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 14px;border-radius:16px;background:linear-gradient(180deg,#ffffffeb,#f5f8faeb);border:1px solid rgba(15,23,42,.06)}.rank-info{display:flex;align-items:center;gap:12px;min-width:0}.rank-index{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:#4caf501f;color:var(--primary-dark);font-size:12px;font-weight:700;flex-shrink:0}.rank-label-group{display:flex;flex-direction:column;min-width:0;gap:2px}.rank-label{color:var(--text-primary);font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rank-subtitle{color:var(--text-light);font-size:12px}.rank-value{color:var(--primary-dark);font-size:15px;font-weight:700;flex-shrink:0}.project-rank-item{align-items:flex-start}.project-rank-info{min-width:0;flex:1}.rank-amount-group{min-width:120px;display:flex;flex-direction:column;align-items:flex-end;gap:8px}.mini-track{width:120px;height:8px;border-radius:999px;background:#0f172a14;overflow:hidden}.mini-fill{height:100%;border-radius:inherit}.admin-projects-collection{display:flex;flex-direction:column;gap:18px}.collection-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.collection-count{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 12px;border-radius:999px;background:#4caf501a;color:var(--primary-dark);font-size:14px;font-weight:700}.empty-projects-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;min-height:240px;padding:32px 20px;border-radius:24px;background:#ffffffe6;border:1px solid rgba(15,23,42,.06);box-shadow:var(--shadow-md);text-align:center}.empty-projects-icon{font-size:42px;line-height:1;display:flex;align-items:center;justify-content:center}.empty-projects-icon svg{width:48px;height:48px;color:var(--榕树绿色);opacity:.6}.empty-projects-title{color:var(--text-secondary);font-size:15px;line-height:1.7}.admin-projects-page .projects-list{margin-top:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px}.admin-projects-page .project-card{position:relative;overflow:hidden;background:#fffffff2;border-radius:24px;padding:22px;box-shadow:var(--shadow-md);border:1px solid rgba(255,255,255,.78);transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}.admin-projects-page .project-card:before{content:"";position:absolute;top:0;left:0;right:0;height:5px}.admin-projects-page .project-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:#4caf5033}.admin-projects-page .project-card.project-card--draft:before{background:linear-gradient(90deg,#ffb74d,#f57c00)}.admin-projects-page .project-card.project-card--pending:before{background:linear-gradient(90deg,#ffe082,#ffb300)}.admin-projects-page .project-card.project-card--approved:before{background:linear-gradient(90deg,#81c784,#388e3c)}.admin-projects-page .project-card.project-card--rejected:before{background:linear-gradient(90deg,#ef9a9a,#d32f2f)}.project-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.project-title-group{min-width:0;flex:1}.project-title-row{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.admin-projects-page .project-card h3{margin:0;font-size:18px;color:var(--text-primary)}.admin-projects-page .cross-company-tag{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:#2196f31a;color:var(--secondary-dark);font-size:12px;font-weight:700}.project-code-pill{display:inline-flex;align-items:center;margin-top:10px;padding:6px 10px;border-radius:999px;background:#0f172a0f;color:var(--text-secondary);font-size:12px;font-weight:600}.admin-projects-page .status-chip{display:inline-flex;align-items:center;padding:6px 12px;border-radius:999px;font-size:12px;font-weight:700;white-space:nowrap}.admin-projects-page .status-chip.status-draft{background-color:#fff3e0;color:#ef6c00}.admin-projects-page .status-chip.status-pending{background-color:#fff8e1;color:#f9a825}.admin-projects-page .status-chip.status-approved{background-color:#e8f5e9;color:#2e7d32}.admin-projects-page .status-chip.status-rejected{background-color:#ffebee;color:#c62828}.project-highlights{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:18px}.project-highlight{padding:14px;border-radius:16px;background:linear-gradient(180deg,#f8fcf4f2,#e8f5e9b3);border:1px solid rgba(76,175,80,.1)}.project-highlight-label{display:block;color:var(--text-secondary);font-size:12px}.project-highlight-value{display:block;margin-top:8px;color:var(--primary-dark);font-size:20px;font-weight:800;line-height:1.2}.project-finance-owner{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:16px;padding:14px 16px;border-radius:16px;background:#2196f30f;border:1px solid rgba(33,150,243,.1)}.project-finance-label{color:var(--text-secondary);font-size:12px;font-weight:600}.project-finance-name{color:var(--secondary-dark);font-size:15px;font-weight:700;text-align:right}.project-section{margin-top:16px;padding-top:16px;border-top:1px solid rgba(15,23,42,.06)}.project-section-label{display:block;margin-bottom:8px;color:var(--text-light);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.admin-projects-page .project-goal{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.7}.expense-track-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px;font-size:13px;color:var(--text-secondary)}.expense-track-header strong{color:var(--text-primary)}.project-expense-track{height:12px}.project-member-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}.project-member-pill{padding:12px 14px;border-radius:16px;background:linear-gradient(180deg,#fffffff5,#f7f9faf0);border:1px solid rgba(15,23,42,.06)}.member-pill-header{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.member-role-badge{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;background:#4caf501f;color:var(--primary-dark);font-size:11px;font-weight:700}.member-role-badge.is-leader{background:#ffb30029;color:#8d5b00}.member-name{color:var(--text-primary);font-size:14px;font-weight:600}.member-share{margin-left:auto;color:var(--primary-dark);font-size:13px;font-weight:700}.member-pill-details{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.member-detail-chip{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;background:#0f172a0d;color:var(--text-secondary);font-size:12px}.admin-projects-page .company-tag{background:#2196f314;color:var(--secondary-dark)}.admin-projects-page .project-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px;font-size:12px}.admin-projects-page .company-chip,.admin-projects-page .date-chip{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background-color:#0f172a0d;color:var(--text-secondary)}@media(max-width:1100px){.admin-projects-summary{grid-template-columns:1fr}.admin-projects-side-panels{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:900px){.admin-projects-insights{grid-template-columns:1fr}}@media(max-width:767px){.admin-projects-header{flex-direction:column;align-items:flex-start}.projects-version-badge{white-space:normal}.admin-projects-hero{padding:22px}.hero-value{font-size:44px}.hero-status-strip,.project-highlights,.key-metrics-panel{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-projects-side-panels,.admin-projects-page .projects-list{grid-template-columns:1fr}.project-card-top,.project-finance-owner,.expense-track-header,.rank-list-item,.project-rank-item{flex-direction:column;align-items:flex-start}.rank-amount-group{width:100%;min-width:0;align-items:flex-start}.mini-track{width:100%}}@media(max-width:480px){.hero-status-strip,.project-highlights,.key-metrics-panel,.project-member-list{grid-template-columns:1fr}.summary-value,.project-highlight-value{font-size:18px}.hero-value{font-size:36px}}.staff-list{margin-top:24px}.staff-list h2{font-size:18px;margin-bottom:20px;color:var(--榕树深绿);font-weight:600;display:flex;align-items:center;padding-bottom:12px;border-bottom:2px solid var(--榕树浅绿)}.staff-list h2:before{content:"👥";margin-right:10px;font-size:18px}.staff-actions{display:flex;gap:10px;margin-top:16px;padding-top:16px;border-top:1px solid var(--榕树浅绿)}.staff-actions button{flex:1;text-align:center}.navbar{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(180deg,#fffffff7,#f8fcf8f2);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;justify-content:space-around;align-items:center;padding:8px 8px max(8px,env(safe-area-inset-bottom));box-shadow:0 -4px 24px #4caf5014;z-index:100;border-top:1px solid rgba(76,175,80,.15)}.navbar a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;text-decoration:none;color:var(--text-secondary);font-size:11px;padding:10px 12px;border-radius:20px;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;margin:0 2px;min-width:56px;flex:1;max-width:88px}.navbar a:hover{background:#4caf5014;color:var(--榕树深绿)}.navbar a.active{color:var(--榕树深绿);font-weight:600;background:linear-gradient(135deg,#4caf501f,#4caf500f);box-shadow:inset 0 1px #fff9,0 2px 8px #4caf501f}.navbar a.active:after{content:"";position:absolute;bottom:-2px;left:50%;transform:translate(-50%);width:20px;height:3px;background:linear-gradient(90deg,var(--榕树绿色),var(--榕树深绿));border-radius:3px 3px 0 0}.nav-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;margin:0;transition:all .25s ease}.nav-icon svg{width:22px;height:22px}.navbar a.active .nav-icon{transform:scale(1.08)}.navbar a.active .nav-icon svg{color:var(--榕树绿色)}.nav-text{font-size:11px;font-weight:500;letter-spacing:.02em;transition:all .25s ease}.navbar a.active .nav-text{font-weight:600}.login-page{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:var(--space-lg);box-sizing:border-box}.login-container{background-color:var(--background-white);padding:var(--space-2xl);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);max-width:420px;width:100%;text-align:center;border-top:4px solid var(--榕树绿色);position:relative;z-index:2}.login-container h1{font-size:1.75rem;margin-bottom:var(--space-md);color:var(--text-primary);font-weight:700;letter-spacing:.02em}.login-form{margin-bottom:var(--space-xl)}.login-form .form-group{margin-bottom:var(--space-lg);text-align:left}.login-form .submit-button{width:100%;padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);font-size:1rem;font-weight:600;margin-top:var(--space-sm)}.login-hint{background-color:var(--background-light);padding:var(--space-lg);border-radius:var(--radius-md);text-align:left;border:1px solid var(--border-color)}.login-hint h3{font-size:1rem;margin-bottom:var(--space-sm);color:var(--text-secondary);font-weight:600}.login-hint p{margin-bottom:var(--space-sm);color:var(--text-secondary);font-size:.875rem;line-height:1.5}@media(min-width:768px){.main-content{padding-bottom:var(--space-xl)}.navbar{display:none!important}.layout{max-width:var(--content-max);margin:0 auto;box-shadow:0 0 0 1px var(--border-color)}.header-content{max-width:var(--content-max)}.sidebar{position:fixed;top:0;right:-300px;width:300px;max-width:90vw;height:100vh;background:var(--background-white);box-shadow:var(--shadow-lg);z-index:1001;transition:right .25s ease;overflow-y:auto;border-radius:var(--radius-lg) 0 0 var(--radius-lg)}.sidebar.open{right:0}.sidebar-content{padding:24px}.sidebar-nav{display:flex;flex-direction:column;gap:8px}.sidebar-nav a{display:flex;align-items:center;gap:12px;padding:12px 16px;text-decoration:none;color:var(--text-secondary);border-radius:8px;transition:all .2s ease}.sidebar-nav a:hover,.sidebar-nav a.active{background-color:var(--榕树浅绿);color:var(--榕树深绿)}.sidebar-nav a.active{font-weight:600}}.admin-bottom-dock{position:fixed;bottom:0;left:0;right:0;z-index:100;display:flex;flex-direction:column;pointer-events:none}.admin-bottom-dock .navbar,.admin-bottom-dock .app-icp-footer{pointer-events:auto}.admin-bottom-dock .navbar{position:relative!important;bottom:auto!important;left:auto!important;right:auto!important;order:1}.admin-bottom-dock .app-icp-footer{order:2;margin:0;text-align:center;font-size:11px;line-height:1.35;padding:4px 8px;padding-bottom:max(4px,env(safe-area-inset-bottom));background:linear-gradient(180deg,#fffffffa,#f8fcf8);border-top:1px solid rgba(76,175,80,.12)}.admin-bottom-dock .app-icp-footer .icp-beian-line{margin:0}.admin-bottom-dock .app-icp-footer a{color:var(--text-secondary);text-decoration:none}.admin-bottom-dock .app-icp-footer a:hover{text-decoration:underline}.admin-layout .admin-header{display:none;background:linear-gradient(135deg,var(--榕树绿色) 0%,var(--榕树深绿) 100%);color:#fff;padding:12px 20px;box-shadow:0 2px 8px #0000001a;position:sticky;top:0;z-index:100}.admin-layout .admin-brand{margin:0;font-size:18px;font-weight:700}.admin-layout .admin-desktop-nav{display:none;gap:4px}.admin-layout .admin-desktop-nav a{color:#ffffffe6;text-decoration:none;padding:8px 14px;border-radius:8px;font-weight:500;font-size:14px}.admin-layout .admin-desktop-nav a:hover,.admin-layout .admin-desktop-nav a.active{background:#fff3;color:#fff}@media(min-width:768px){.admin-layout .admin-header{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;width:100%;box-sizing:border-box}.admin-layout .admin-desktop-nav{display:flex;align-items:center;flex-wrap:wrap}.admin-layout .admin-bottom-nav{display:none!important}.admin-layout .admin-main{padding-top:16px;padding-bottom:40px}}@media(max-width:767px){.admin-layout .admin-header{display:none!important}.admin-layout .admin-bottom-nav{display:flex!important}.admin-layout .admin-main{padding-top:16px}.admin-layout .main-content{padding-bottom:112px}}@media(max-width:767px){.main-content{padding:15px 15px 90px}.page-header{flex-direction:column;align-items:flex-start;gap:10px}.header-buttons{width:100%;justify-content:space-between}.page-header h1{font-size:20px;color:var(--榕树深绿)}.add-button,.edit-button,.submit-button,.add-member-button,.remove-button,.cancel-button,.delete-button{font-size:12px;padding:8px 16px}.member-item{flex-direction:column;align-items:stretch;gap:8px}.member-item input{width:100%}.remove-button{margin-left:0;width:100%}.card,.project-card,.expense-card,.stat-card{padding:16px}.card h2{font-size:18px}.add-project-form,.add-expense-form,.profile-form{padding:16px}.form-group input,.form-group select,.form-group textarea{padding:10px 14px;font-size:14px}.home-content{grid-template-columns:1fr;gap:16px}.project-card h3{font-size:18px}.expense-header{flex-direction:column;align-items:flex-start;gap:10px}.stats-overview{grid-template-columns:repeat(2,1fr);gap:16px}.stat-value{font-size:24px}.profile-info{padding:16px}.info-item{padding:12px}.admin-stats{grid-template-columns:repeat(2,1fr);gap:16px;margin-top:20px}.admin-stats .stat-card{padding:16px}.admin-stats .stat-value{font-size:28px}.admin-overview{grid-template-columns:1fr;gap:16px}.overview-section{padding:16px}.overview-item{padding:12px}.staff-cards,.finance-stats{grid-template-columns:1fr;gap:16px}.stat-section,.finance-summary{padding:16px}.download-buttons{flex-direction:column}.download-button{width:100%;justify-content:center}.expenses-tabs h3{font-size:16px;margin-top:20px}.navbar{padding:8px 0}.navbar a{padding:6px 12px;min-width:60px}.nav-icon{font-size:20px}.nav-text{font-size:10px}.login-container{padding:24px}.login-container h1{font-size:24px}}@media(max-width:480px){.main-content{padding:12px 12px 70px}.page-header h1{font-size:18px}.add-button,.edit-button,.submit-button,.add-member-button,.remove-button,.cancel-button,.delete-button{font-size:11px;padding:6px 12px}.card,.project-card,.expense-card,.stat-card{padding:12px}.card h2{font-size:16px}.add-project-form,.add-expense-form,.profile-form{padding:12px}.form-group input,.form-group select,.form-group textarea{padding:8px 12px;font-size:13px}.stats-overview{grid-template-columns:1fr;gap:12px}.stat-value{font-size:20px}.navbar a{padding:6px 12px}.nav-icon{font-size:20px}.nav-text{font-size:10px}.login-container{padding:20px}.login-container h1{font-size:20px}}.super-admin-layout{display:flex;flex-direction:column;min-height:100vh;background-color:var(--background-light)}.super-admin-header{background-color:#1a252f;color:#fff;padding:1rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a}.super-admin-header h1{margin:0;font-size:1.5rem;color:#fff}.header-right{display:flex;align-items:center;gap:1rem}.header-logout-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:48px;min-width:48px;padding:8px 14px}.header-logout-btn .header-logout-icon{font-size:1.1rem;display:flex;align-items:center;justify-content:center}.header-logout-btn .header-logout-icon svg{width:18px;height:18px}.header-logout-btn .header-logout-text{white-space:nowrap}@media(max-width:480px){.header-logout-btn .header-logout-text{display:none}.header-logout-btn{padding:10px}}.user-info{font-size:.9rem;color:#fff}.super-admin-content{display:flex;flex:1;min-width:0;min-height:0}.super-admin-sidebar{width:200px;background-color:#2c3e50;color:#fff;padding:1rem 0}.super-admin-sidebar nav ul{list-style:none;padding:0;margin:0}.super-admin-sidebar nav ul li{margin-bottom:.5rem}.super-admin-sidebar nav ul li a{display:flex;align-items:center;padding:.75rem 1rem;color:#fff;text-decoration:none;transition:background-color .3s}.super-admin-sidebar .sidebar-nav-icon{display:flex;align-items:center;justify-content:center;width:22px;height:22px;margin-right:10px;flex-shrink:0}.super-admin-sidebar .sidebar-nav-icon svg{width:20px;height:20px;fill:currentColor}.super-admin-sidebar nav ul li a:hover{background-color:#1a252f}.super-admin-sidebar nav ul li a.active{background-color:#3498db;font-weight:700}.super-admin-main{flex:1;min-width:0;padding:2rem;overflow-y:auto;overflow-x:auto}@media(max-width:767px){.super-admin-content{flex-direction:column;min-height:0;flex:1}.super-admin-sidebar{width:100%;padding:.5rem 0;flex-shrink:0}.super-admin-sidebar nav ul{display:flex;overflow-x:auto;gap:.5rem}.super-admin-sidebar nav ul li{margin-bottom:0}.super-admin-sidebar nav ul li a{padding:.5rem 1rem;white-space:nowrap}.super-admin-main{width:100%;max-width:100%;min-width:0;box-sizing:border-box;padding:1.5rem;min-height:400px;flex:1 1 0;overflow-x:auto;overflow-y:auto;-webkit-overflow-scrolling:touch}}@media(max-width:480px){.super-admin-main{padding:1rem;min-height:350px}.super-admin-header{padding:.75rem}.super-admin-header h1{font-size:1.25rem}.header-right{gap:.5rem}.user-info{font-size:.8rem}}.super-admin-desktop-beian{display:none}@media(min-width:769px){.super-admin-desktop-beian{display:block;position:fixed;bottom:0;left:0;right:0;z-index:99;text-align:center;font-size:11px;line-height:1.35;padding:6px 8px;background:linear-gradient(180deg,#2c3e50fa,#212f3cfa);border-top:1px solid rgba(255,255,255,.08)}.super-admin-desktop-beian .icp-beian-line{margin:0}.super-admin-desktop-beian a{color:#ffffffa6;text-decoration:none}.super-admin-desktop-beian a:hover{color:#ffffffe6;text-decoration:underline}.super-admin-layout .super-admin-main{padding-bottom:2.5rem}}.super-admin-footer{display:none;position:fixed;bottom:0;left:0;right:0;flex-direction:column;background:linear-gradient(180deg,#2c3e50fa,#212f3cfa);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:#fff;padding:0 8px max(10px,env(safe-area-inset-bottom));box-shadow:0 -4px 24px #0003;z-index:100;border-top:1px solid rgba(255,255,255,.08)}.super-admin-icp{text-align:center;font-size:11px;line-height:1.35;padding:6px 4px 4px;border-bottom:1px solid rgba(255,255,255,.08)}.super-admin-icp .icp-beian-line{margin:0}.super-admin-icp a{color:#ffffffa6;text-decoration:none}.super-admin-icp a:hover{color:#ffffffe6;text-decoration:underline}.super-admin-footer .footer-nav{display:flex;justify-content:space-around;align-items:center;gap:4px;padding-top:8px}.super-admin-footer .footer-nav a{color:#ffffffbf;text-decoration:none;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:10px 12px;border-radius:18px;transition:all .25s cubic-bezier(.4,0,.2,1);flex:1;max-width:72px}.super-admin-footer .footer-nav a:hover{color:#fff;background:#ffffff14}.super-admin-footer .footer-nav a .nav-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;margin:0}.super-admin-footer .footer-nav a .nav-icon svg{width:22px;height:22px}.super-admin-footer .footer-nav a .nav-text{font-size:11px;font-weight:500}.super-admin-footer .footer-nav a.active{color:#5dade2;font-weight:600;background:#5dade226}.super-admin-footer .footer-nav a.active .nav-icon svg{fill:#5dade2}.dashboard-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.super-admin-dashboard{max-width:1200px;margin:0 auto;padding:20px}.dashboard-section{background-color:var(--background-white);padding:24px;border-radius:12px;box-shadow:var(--shadow);margin-bottom:30px;border:1px solid var(--border-color)}.dashboard-section h2{font-size:18px;margin-bottom:20px;color:var(--text-primary);font-weight:600;display:flex;align-items:center}.chart-container{width:100%;height:350px;min-height:240px;min-width:200px;position:relative;margin-top:10px;padding:10px;box-sizing:border-box}.recharts-legend-wrapper{margin-top:10px!important;margin-bottom:10px!important}.recharts-legend-item{margin-right:15px!important}.recharts-legend-item-text{font-size:12px!important;white-space:nowrap!important}@media(max-width:767px){.super-admin-dashboard{padding:15px;width:100%;min-width:0;overflow-x:auto;box-sizing:border-box}.dashboard-section{padding:16px;margin-bottom:24px;min-width:0}.dashboard-section h2{font-size:16px;margin-bottom:16px}.chart-container{height:300px;min-height:220px;min-width:200px;width:100%;margin-top:8px;padding:8px;box-sizing:border-box}.recharts-legend-item{margin-right:10px!important}.recharts-legend-item-text{font-size:10px!important}}@media(max-width:500px){.super-admin-dashboard{padding:10px}.dashboard-section{padding:10px;margin-bottom:24px;border-radius:8px}.dashboard-section h2{font-size:14px;margin-bottom:12px}.chart-container{height:300px;margin-top:8px;padding:6px}.recharts-legend-item{margin-right:8px!important}.recharts-legend-item-text{font-size:9px!important}.recharts-legend-wrapper{flex-wrap:wrap!important}}@media(max-width:480px){.super-admin-dashboard{padding:8px;width:100%;min-width:0;overflow-x:auto}.dashboard-section{padding:8px;margin-bottom:20px;min-width:0}.dashboard-section h2{font-size:13px;margin-bottom:10px}.chart-container{height:240px;min-height:180px;min-width:200px;width:100%;margin-top:6px;padding:4px;box-sizing:border-box}.recharts-legend-item{margin-right:6px!important}.recharts-legend-item-text{font-size:8px!important}}.online-users-visualization{margin-top:20px}.companies-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.company-circle{background-color:#00000005;padding:20px;border-radius:12px;border:1px solid var(--border-color);text-align:center}.company-name{font-weight:600;margin-bottom:15px;color:var(--text-primary)}.users-container{margin-bottom:15px}.online-count{font-size:14px;color:var(--text-secondary);font-weight:500}.user-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background-color:#000c;color:#fff;padding:8px 12px;border-radius:6px;font-size:12px;white-space:nowrap;z-index:10;margin-bottom:8px;opacity:0;visibility:hidden;transition:all .3s ease}.user-circle:hover .user-tooltip{opacity:1;visibility:visible}.user-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border-width:5px;border-style:solid;border-color:rgba(0,0,0,.8) transparent transparent transparent}.tooltip-type{font-size:11px;margin-bottom:4px;opacity:.9}.tooltip-status{font-size:11px;opacity:.8}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 0;text-align:center}.loading-spinner{width:40px;height:40px;border:4px solid rgba(76,175,80,.3);border-radius:50%;border-top:4px solid var(--primary-color);animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}to{transform:scale(1);opacity:1}}.dashboard-card{background-color:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;text-align:center}.dashboard-card h3{margin-top:0;color:#333;font-size:1rem;font-weight:400}.card-value{font-size:2rem;font-weight:700;color:#3498db;margin:.5rem 0 0}.recent-activity{background-color:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.recent-activity h2{margin-top:0;color:#333;font-size:1.25rem}.companies-list{margin-top:2rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:1.5rem}.company-card{background-color:#fff;padding:2rem;border-radius:12px;box-shadow:var(--shadow);transition:all .3s ease;border:1px solid var(--border-color);position:relative;overflow:hidden}.company-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-light)}.company-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(to bottom,var(--primary-color),var(--primary-light));border-radius:12px 0 0 12px}.company-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.company-header h3{margin:0;color:var(--text-primary);font-size:1.25rem;font-weight:600;display:flex;align-items:center}.company-header h3:before{content:"🏢";margin-right:10px;font-size:1.2rem}.company-code{background-color:#3498db1a;color:var(--secondary-color);padding:.35rem 1rem;border-radius:20px;font-size:.85rem;font-weight:600;border:1px solid var(--secondary-light)}.company-description{color:var(--text-secondary);margin-bottom:1.5rem;line-height:1.5;padding:1rem;background-color:#00000005;border-radius:8px;border-left:3px solid var(--secondary-light)}.company-info{background-color:#4caf500d;padding:1.25rem;border-radius:8px;margin-bottom:1.5rem;border:1px solid rgba(76,175,80,.2)}.company-info p{margin:0 0 .75rem;color:var(--text-primary);font-weight:500;display:flex;align-items:center;font-size:.95rem}.company-info p:last-child{margin-bottom:0}.company-info p:before{content:"📋";margin-right:8px;font-size:1rem}.company-info p:nth-child(1):before{content:"👥"}.company-info p:nth-child(2):before{content:"📅"}.company-info p:nth-child(3):before{content:"👤"}.company-info p:nth-child(4):before{content:"📁"}.extend-records-button{background-color:var(--secondary-color);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .3s ease;margin:1rem 0;width:100%;box-shadow:var(--shadow)}.extend-records-button:hover{background-color:var(--secondary-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.extend-records{background-color:#ff98000d;padding:1rem;border-radius:8px;margin-top:1rem;border:1px solid rgba(255,152,0,.2)}.extend-records ul{list-style:none;padding:0;margin:0}.extend-records li{padding:.75rem;border-bottom:1px solid rgba(255,152,0,.1);margin-bottom:.5rem;border-radius:6px;background-color:#ff980008;transition:all .2s ease}.extend-records li:hover{background-color:#ff980014;transform:translate(4px)}.extend-records li:last-child{border-bottom:none;margin-bottom:0}.company-actions{display:flex;gap:.75rem;flex-wrap:wrap}.add-admin-button,.extend-button{padding:.6rem 1.2rem;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .3s ease;box-shadow:var(--shadow)}.add-admin-button{background-color:var(--secondary-color);color:#fff}.add-admin-button:hover{background-color:var(--secondary-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.extend-button{background-color:var(--accent-color);color:#fff}.extend-button:hover{background-color:var(--accent-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.add-company-form,.add-admin-form{background-color:#fff;padding:2rem;border-radius:12px;box-shadow:var(--shadow-lg);margin-bottom:2rem;border-top:4px solid var(--primary-color)}.add-company-form h3,.add-admin-form h3{margin-top:0;color:var(--text-primary);margin-bottom:1.5rem;font-size:1.25rem;font-weight:600;display:flex;align-items:center}.add-company-form h3:before{content:"🏢";margin-right:10px;font-size:1.2rem}.form-actions{display:flex;gap:1rem;margin-top:2rem;justify-content:flex-end;padding-top:1.5rem;border-top:1px solid var(--border-color)}.admin-list{margin-top:1rem}.admin-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background-color:#00000005;border-radius:8px;margin-bottom:.75rem;border:1px solid var(--border-color);transition:all .3s ease}.admin-item:hover{background-color:#0000000d;transform:translate(4px);border-color:var(--primary-light)}.admin-actions{display:flex;gap:.5rem}.edit-admin-button{background-color:var(--primary-color);color:#fff;border:none;padding:.4rem .8rem;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;transition:all .3s ease;box-shadow:var(--shadow)}.edit-admin-button:hover{background-color:var(--primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-lg)}.remove-admin-button{background-color:var(--error-color);color:#fff;border:none;padding:.4rem .8rem;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;transition:all .3s ease;box-shadow:var(--shadow);margin-left:0}.remove-admin-button:hover{background-color:var(--error-dark);transform:translateY(-1px);box-shadow:var(--shadow-lg)}.add-admin-form h3{display:flex;align-items:center}.add-admin-form h3:before{content:"📅";margin-right:10px;font-size:1.2rem}.add-admin-form h3:before{content:"👤";margin-right:10px;font-size:1.2rem}@media(max-width:768px){.super-admin-content{flex-direction:column;min-height:0;flex:1;width:100%}.super-admin-sidebar{width:100%;min-width:0;padding:.5rem 0;flex-shrink:0}.super-admin-sidebar nav ul{display:flex;overflow-x:auto;gap:.5rem;padding:0 .5rem}.super-admin-sidebar nav ul li{margin-bottom:0}.super-admin-sidebar nav ul li a{white-space:nowrap;padding:.5rem .75rem;border-radius:4px}.super-admin-main{width:100%;min-width:0;min-height:0;padding:1rem 1rem 5rem;flex:1 1 0;overflow-x:auto;overflow-y:auto;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column}.super-admin-footer{display:flex;flex-direction:column}.super-admin-dashboard{width:100%;min-width:0;display:block;overflow:visible;padding-bottom:3rem}.super-admin-dashboard .dashboard-section{min-width:0;overflow:visible}.super-admin-dashboard .chart-container{width:100%!important;max-width:100%;min-width:260px;height:240px;min-height:200px;flex-shrink:0;position:relative}.super-admin-dashboard .online-users-visualization,.super-admin-dashboard .companies-container{min-width:0;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch}.super-admin-dashboard .company-circle{min-width:0;width:100%}.super-admin-dashboard .user-summary-grid{width:100%;min-width:0;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}.super-admin-dashboard .user-summary-card{min-width:0;width:100%}.super-admin-dashboard .dashboard-section:last-child{margin-bottom:2rem;padding-bottom:2rem}.super-admin-dashboard .user-table-container{width:100%;min-width:0;min-height:180px;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;margin-top:1rem;display:block}.super-admin-dashboard .user-table{min-width:480px;display:table;width:100%}.super-admin-dashboard .user-table th,.super-admin-dashboard .user-table td{white-space:normal;padding:.5rem .4rem;font-size:.8rem}.super-admin-users{width:100%;min-width:0;display:flex;flex-direction:column;flex:1 1 auto}.super-admin-users .stats-section,.super-admin-users .filter-section,.super-admin-users .users-list{width:100%;min-width:0;flex-shrink:0}.super-admin-users .users-list{flex:1 1 auto;min-height:200px;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;margin-top:.5rem}.super-admin-users .users-table{min-width:480px;display:table}.super-admin-users .users-table th,.super-admin-users .users-table td{white-space:normal;padding:.5rem .4rem;font-size:.85rem}.dashboard-cards{grid-template-columns:repeat(2,1fr);gap:1rem}.card-value{font-size:1.5rem}.companies-list{grid-template-columns:1fr;gap:1rem}.company-card{padding:1.5rem}.company-actions{flex-direction:column}.add-admin-button,.extend-button,.edit-button,.delete-button{width:100%}.admin-actions{flex-direction:column;width:100%}.edit-admin-button,.remove-admin-button{width:100%}.add-company-form,.add-admin-form{padding:1.5rem}.form-actions{flex-direction:column;gap:.75rem}.form-actions button{width:100%}}@media(max-width:480px){.super-admin-main{padding:.75rem;min-height:350px}.super-admin-header{flex-direction:column;align-items:flex-start;gap:.5rem}.header-right{width:100%;justify-content:space-between}.super-admin-header h1{font-size:1.25rem}.dashboard-cards{grid-template-columns:1fr;gap:.75rem}.card-value{font-size:1.25rem}.companies-list{gap:.75rem}.company-card{padding:1rem}.company-header h3{font-size:1rem}.company-info p{font-size:.85rem}.add-company-form,.add-admin-form{padding:1rem}.add-company-form h3,.add-admin-form h3{font-size:1.1rem}.form-group input,.form-group select,.form-group textarea{padding:.75rem;font-size:.9rem}.super-admin-users{padding:.75rem}.stats-grid{grid-template-columns:1fr;gap:.75rem}.users-table th,.users-table td{padding:.5rem;font-size:12px}.modal-content{margin:.5rem}.modal-header,.modal-body{padding:1rem}.company-basic-info h3,.company-stats h3,.company-users h3,.company-projects h3,.company-expenses h3{font-size:1.1rem}}.admin-auditor-page{max-width:1200px;margin:0 auto;padding:20px}.audit-summary{background-color:var(--background-white);padding:24px;border-radius:12px;box-shadow:var(--shadow);margin-bottom:24px;border-top:4px solid var(--accent-color)}.audit-summary h2{font-size:20px;margin-bottom:16px;color:var(--text-primary);font-weight:600;display:flex;align-items:center}.audit-summary h2:before{content:"📋";margin-right:10px;font-size:18px}.audit-summary p{margin-bottom:8px;color:var(--text-secondary);font-size:14px;display:flex;align-items:center}.audit-summary p:before{content:"📌";margin-right:8px;font-size:14px}.audit-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-bottom:30px}.stat-section{background-color:var(--background-white);padding:24px;border-radius:12px;box-shadow:var(--shadow);border:1px solid var(--border-color)}.stat-section h3{font-size:18px;margin-bottom:16px;color:var(--text-primary);font-weight:600;display:flex;align-items:center}.stat-section h3:before{content:"📊";margin-right:10px;font-size:16px}.project-list{margin-top:16px}.project-card{background-color:var(--background-white);padding:20px;border-radius:8px;border:1px solid var(--border-color);margin-bottom:16px;transition:all .3s ease;box-shadow:var(--shadow)}.project-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-light)}.project-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--border-color)}.project-header h4{font-size:16px;color:var(--text-primary);font-weight:600;margin:0}.project-code{font-size:12px;color:var(--text-secondary);background-color:#00000005;padding:4px 8px;border-radius:4px;border:1px solid var(--border-color)}.project-goal{margin-bottom:16px;color:var(--text-secondary);font-size:14px;line-height:1.4;padding:12px;background-color:#2196f30d;border-radius:8px;border-left:4px solid var(--secondary-light)}.project-audit-status{margin-bottom:16px}.status-badge{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;display:inline-block}.status-badge.pending{background-color:#ffc1071a;color:#ff9800;border:1px solid rgba(255,152,0,.3)}.status-badge.approved{background-color:#4caf501a;color:var(--primary-color);border:1px solid rgba(76,175,80,.3)}.status-badge.rejected{background-color:#f443361a;color:var(--error-color);border:1px solid rgba(244,67,54,.3)}.project-auditors{margin-bottom:16px}.project-auditors h5{font-size:14px;margin-bottom:12px;color:var(--text-secondary);font-weight:500;display:flex;align-items:center}.project-auditors h5:before{content:"👥";margin-right:8px;font-size:14px}.project-auditors ul{list-style:none;padding:0;margin:0}.project-auditors li{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;border-bottom:1px solid var(--border-color);margin-bottom:8px;border-radius:6px;background-color:#00000005;transition:all .2s ease}.project-auditors li:hover{background-color:#0000000d;transform:translate(4px)}.auditor-name{font-size:14px;color:var(--text-primary);font-weight:500}.audit-status-badge{padding:4px 8px;border-radius:12px;font-size:11px;font-weight:600;display:inline-block}.audit-status-badge.pending{background-color:#ffc1071a;color:#ff9800;border:1px solid rgba(255,152,0,.3)}.audit-status-badge.approved{background-color:#4caf501a;color:var(--primary-color);border:1px solid rgba(76,175,80,.3)}.audit-status-badge.rejected{background-color:#f443361a;color:var(--error-color);border:1px solid rgba(244,67,54,.3)}.audit-actions{display:flex;gap:12px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border-color)}.approve-button{background-color:var(--primary-color);color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;box-shadow:var(--shadow);flex:1}.approve-button:hover{background-color:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.reject-button{background-color:var(--error-color);color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;box-shadow:var(--shadow);flex:1;margin-left:0}.reject-button:hover{background-color:var(--error-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.audit-status{margin-top:16px;padding:12px;background-color:#2196f30d;border-radius:8px;border-left:4px solid var(--secondary-color)}.audit-status p{margin:0;color:var(--text-secondary);font-size:14px;display:flex;align-items:center;gap:8px}@keyframes pulse{0%{transform:scale(1);box-shadow:0 0 #4caf50b3}70%{transform:scale(1.05);box-shadow:0 0 0 10px #4caf5000}to{transform:scale(1);box-shadow:0 0 #4caf5000}}.username-change-hint{color:var(--text-light);font-size:12px;margin-left:8px;font-style:italic}.add-audit-form{background-color:var(--background-white);padding:24px;border-radius:12px;box-shadow:var(--shadow-lg);margin-bottom:24px;border-top:4px solid var(--accent-color)}.add-audit-form h2{font-size:18px;margin-bottom:16px;color:var(--text-primary);font-weight:600;display:flex;align-items:center}.add-audit-form h2:before{content:"➕";margin-right:10px;font-size:16px}.add-audit-form p{margin-bottom:20px;color:var(--text-secondary);font-size:14px}.empty-message{text-align:center;color:var(--text-light);padding:40px 20px;background-color:var(--background-white);border-radius:8px;box-shadow:var(--shadow);border:1px dashed var(--border-color)}@media(max-width:768px){.admin-auditor-page{padding:15px}.audit-stats{grid-template-columns:1fr;gap:16px}.project-card{padding:16px}.audit-actions{flex-direction:column}.approve-button,.reject-button{width:100%}.project-auditors li{flex-direction:column;align-items:flex-start;gap:8px}.audit-status-badge{align-self:flex-end}.add-audit-form{padding:16px}.add-audit-form h2{font-size:16px}.form-group input,.form-group select,.form-group textarea{padding:10px 14px;font-size:14px}.form-actions{flex-direction:column;gap:10px}.form-actions button{width:100%}}@media(max-width:480px){.admin-auditor-page,.audit-summary{padding:12px}.audit-summary h2{font-size:18px}.stat-section{padding:16px}.stat-section h3{font-size:16px}.project-card{padding:12px}.project-header h4{font-size:14px}.project-goal{padding:10px;font-size:13px}.project-auditors h5{font-size:13px}.project-auditors li{padding:8px 10px}.auditor-name{font-size:13px}.add-audit-form{padding:12px}.add-audit-form h2{font-size:14px}.form-group input,.form-group select,.form-group textarea{padding:8px 12px;font-size:13px}.approve-button,.reject-button{padding:8px 16px;font-size:13px}.audit-status{padding:10px;font-size:13px}}.super-admin-users{padding:1rem}.stats-section{background-color:var(--background-white);padding:1.5rem;border-radius:8px;box-shadow:var(--shadow);margin-bottom:2rem}.stats-section h2{margin-bottom:1.5rem;color:var(--text-primary)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background-color:#00000005;padding:1rem;border-radius:6px;text-align:center;border:1px solid var(--border-color);transition:all .3s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.stat-card h3{margin-bottom:.5rem;font-size:.9rem;color:var(--text-secondary);font-weight:400}.stat-value{font-size:1.5rem;font-weight:700;color:var(--primary-color);margin:0}.company-stats{margin-top:2rem}.company-stats h3{margin-bottom:1rem;color:var(--text-primary)}.company-stats-list{display:flex;flex-direction:column;gap:.5rem}.company-stat-item{display:flex;justify-content:space-between;padding:.75rem;background-color:#00000005;border-radius:6px;border:1px solid var(--border-color)}.company-name{font-weight:500;color:var(--text-primary)}.company-count{color:var(--text-secondary)}.filter-section{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:.5rem;flex:1;min-width:200px}.filter-group label{font-weight:500;color:var(--text-primary)}.filter-group select{padding:.75rem;border:1px solid var(--border-color);border-radius:6px;background-color:#fff;font-size:1rem}.users-list{background-color:var(--background-white);padding:1.5rem;border-radius:8px;box-shadow:var(--shadow)}.users-table{width:100%;border-collapse:collapse}.users-table th,.users-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border-color)}.users-table th{background-color:#00000005;font-weight:600;color:var(--text-primary)}.users-table tr:hover{background-color:#00000005}.company-details-modal{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background-color:#fff;border-radius:8px;box-shadow:var(--shadow-lg);max-width:800px;width:100%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-color);background-color:var(--background-light);border-radius:8px 8px 0 0}.modal-header h2{margin:0;color:var(--text-primary)}.close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary);padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s ease}.close-button:hover{background-color:#0000001a;color:var(--text-primary)}.modal-body{padding:1.5rem}.company-basic-info,.company-stats,.company-users,.company-projects,.company-expenses{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.company-basic-info h3,.company-stats h3,.company-users h3,.company-projects h3,.company-expenses h3{margin-bottom:1rem;color:var(--text-primary)}.company-basic-info p{margin-bottom:.5rem}.projects-list{list-style:none;padding:0;margin:0}.projects-list li{padding:.75rem;background-color:#00000005;border-radius:6px;margin-bottom:.5rem;border:1px solid var(--border-color)}.expenses-table{width:100%;border-collapse:collapse;margin-top:1rem}.expenses-table th,.expenses-table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--border-color)}.expenses-table th{background-color:#00000005;font-weight:600;color:var(--text-primary)}.super-admin-dashboard{padding:1rem;min-width:0;width:100%;box-sizing:border-box}.dashboard-section{background-color:var(--background-white);padding:1.5rem;border-radius:12px;box-shadow:var(--shadow);margin-bottom:2rem;border-top:4px solid var(--primary-color);min-width:0}.dashboard-section h2{font-size:1.5rem;margin-bottom:1.5rem;color:var(--text-primary);font-weight:600;display:flex;align-items:center}.dashboard-section h2:before{content:"📊";margin-right:10px;font-size:1.2rem}.dashboard-section-subtitle{font-size:.9rem;color:var(--text-secondary);margin-top:-.75rem;margin-bottom:1.25rem}.online-users-definition-note{font-size:.8rem;color:var(--text-secondary);margin-top:1rem;padding:.75rem 1rem;background:#00000008;border-radius:8px;border-left:3px solid var(--primary-color);line-height:1.5}.user-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;margin-bottom:1.5rem}.user-summary-card{background-color:#00000005;border-radius:10px;padding:1rem 1.25rem;border:1px solid var(--border-color);display:flex;flex-direction:column;justify-content:center}.user-summary-label{font-size:.9rem;color:var(--text-secondary);margin-bottom:.5rem}.user-summary-value{font-size:1.4rem;font-weight:600;color:var(--primary-color)}.user-table-container{margin-top:.5rem;overflow-x:auto}.user-table{width:100%;border-collapse:collapse;font-size:.9rem}.user-table th,.user-table td{padding:.6rem .75rem;border-bottom:1px solid var(--border-color);text-align:left;white-space:nowrap}.user-table th{background-color:#00000005;font-weight:600;color:var(--text-secondary)}.user-table tr:hover td{background-color:#00000005}.user-table-empty{text-align:center;color:var(--text-secondary)}.online-users-visualization{overflow-x:auto;overflow-y:visible;padding:1rem 0;min-width:0;-webkit-overflow-scrolling:touch}.companies-container{display:flex;gap:2rem;padding:1rem;min-width:0}.company-circle{flex:1;min-width:200px;background-color:#00000005;padding:1.5rem;border-radius:12px;border:1px solid var(--border-color);text-align:center}.company-name{font-size:1.1rem;font-weight:600;margin-bottom:1rem;color:var(--text-primary)}.users-container{margin:1rem 0;min-height:100px;display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:.5rem}.user-circle{transition:all .3s ease;position:relative}.user-circle:hover{transform:scale(1.15);box-shadow:0 4px 12px #0003}.user-circle.online{animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 0 #4caf50b3;transform:scale(1)}70%{box-shadow:0 0 0 10px #4caf5000;transform:scale(1.05)}to{box-shadow:0 0 #4caf5000;transform:scale(1)}}.user-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background-color:#000000d9;color:#fff;padding:8px 12px;border-radius:6px;font-size:12px;white-space:nowrap;z-index:1000;opacity:0;visibility:hidden;transition:all .3s ease;margin-bottom:8px;box-shadow:0 2px 8px #0003}.user-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border-width:4px;border-style:solid;border-color:rgba(0,0,0,.85) transparent transparent transparent}.user-circle:hover .user-tooltip{opacity:1;visibility:visible;bottom:110%}.tooltip-name{font-weight:700;margin-bottom:4px}.tooltip-type{font-size:11px;opacity:.9;margin-bottom:2px}.tooltip-status{font-size:10px;opacity:.8;text-align:center;margin-top:4px;padding-top:4px;border-top:1px solid rgba(255,255,255,.2)}.online-count{margin-top:1rem;font-size:.9rem;color:var(--text-secondary);font-weight:500}.chart-container{width:100%;min-width:0;height:300px;min-height:240px;margin-top:1rem;position:relative}@media(max-width:768px){.super-admin-dashboard{padding:.75rem}.dashboard-section{padding:1rem}.dashboard-section h2{font-size:1.25rem}.companies-container{flex-direction:column;gap:1rem}.company-circle{min-width:100%}.chart-container{height:250px;min-height:220px}.user-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:480px){.super-admin-dashboard .page-header h1{font-size:1.1rem}.super-admin-dashboard .dashboard-section h2{font-size:1rem}.super-admin-dashboard .dashboard-section-subtitle,.super-admin-dashboard .user-summary-label{font-size:.85rem}.super-admin-dashboard .user-summary-value{font-size:1.2rem}.super-admin-dashboard .company-name{font-size:.95rem}.super-admin-dashboard .online-count{font-size:.85rem}.super-admin-dashboard .user-table{font-size:.8rem}.super-admin-dashboard .user-table th,.super-admin-dashboard .user-table td{padding:.5rem .4rem;white-space:normal}}@media(max-width:480px){.dashboard-section{padding:.75rem}.dashboard-section h2{font-size:1.1rem}.company-circle{padding:1rem}.company-name{font-size:1rem}.users-container{min-height:80px}.user-circle{width:25px!important;height:25px!important;margin:3px!important}.chart-container{height:220px;min-height:200px}.user-summary-grid{grid-template-columns:1fr}.super-admin-dashboard .user-summary-grid{grid-template-columns:1fr;gap:.5rem}.super-admin-dashboard .user-table,.super-admin-users .users-table{min-width:320px}}.recharts-wrapper{min-width:0!important}.recharts-surface{overflow:visible}.super-admin-dashboard .recharts-cartesian-grid-horizontal line,.super-admin-dashboard .recharts-cartesian-grid-vertical line{stroke-opacity:.3}@media(max-width:768px){.filter-section{flex-direction:column}.filter-group{min-width:100%}.stats-grid{grid-template-columns:repeat(2,1fr)}.modal-content{max-height:95vh}.modal-body{padding:1rem}.users-table,.expenses-table{font-size:.9rem}.users-table th,.users-table td,.expenses-table th,.expenses-table td{padding:.5rem}.form-actions{flex-direction:column;gap:.75rem}.form-actions button{width:100%}}@media(max-width:480px){.super-admin-users{padding:.75rem}.stats-section{padding:1rem}.stats-section h2{font-size:1.25rem}.stats-grid{grid-template-columns:1fr;gap:.75rem}.stat-card{padding:.75rem}.stat-card h3{font-size:.8rem}.stat-value{font-size:1.25rem}.filter-section{gap:.75rem}.filter-group select{padding:.6rem;font-size:.9rem}.users-list{padding:1rem}.users-table{font-size:12px}.users-table th,.users-table td{padding:.5rem}.modal-content{margin:.5rem}.modal-header{padding:1rem}.modal-header h2{font-size:1.25rem}.modal-body{padding:1rem}.company-basic-info h3,.company-stats h3,.company-users h3,.company-projects h3,.company-expenses h3{font-size:1.1rem}.company-basic-info p{font-size:.9rem}.projects-list li{padding:.75rem;font-size:.9rem}.expenses-table{font-size:12px}.expenses-table th,.expenses-table td{padding:.5rem}}.page.role-home{padding:1rem;max-width:1200px;margin:0 auto}.role-home .page-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}.role-home .header-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.role-home .primary-button{display:inline-flex;align-items:center;padding:.5rem 1rem;background:var(--榕树绿色);color:#fff;border-radius:8px;text-decoration:none;font-weight:500}.role-home .primary-button.outline{background:transparent;color:var(--榕树绿色);border:2px solid var(--榕树绿色)}.role-home .primary-button:hover{opacity:.9}.role-home .dashboard-section{margin-bottom:var(--space-lg);padding:var(--space-lg);background:var(--background-white);border-radius:var(--radius-lg);box-shadow:var(--shadow);border:1px solid var(--border-color)}.role-home .dashboard-section h2{margin-bottom:var(--space-md);border-bottom:2px solid var(--榕树浅绿);padding-bottom:var(--space-sm);font-size:1.125rem;font-weight:600;color:var(--text-primary)}.role-home .stat-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem}.role-home .stat-cards.small{grid-template-columns:repeat(3,1fr);max-width:360px}.role-home .stat-card{padding:var(--space-lg);background:var(--榕树浅绿);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--space-xs);border:1px solid rgba(76,175,80,.2);transition:box-shadow .2s ease,transform .15s ease}.role-home .stat-card:hover{box-shadow:var(--shadow)}.role-home .stat-card.highlight{background:#fff8e1;border:1px solid var(--accent-color)}.role-home .stat-card.link-card{text-decoration:none;color:inherit;transition:transform .2s}.role-home .stat-card.link-card:hover{transform:translateY(-2px)}.role-home .stat-card .stat-label{font-size:.875rem;color:var(--text-secondary)}.role-home .stat-card .stat-value{font-size:1.25rem;font-weight:700;color:var(--榕树深绿)}.default-home-welcome{margin:-.5rem 0 1.25rem;font-size:.95rem;color:var(--text-secondary)}.default-home .default-home-stats .stat-cards{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.default-home .stat-card .stat-icon{font-size:1.25rem;margin-bottom:.25rem;display:flex;align-items:center;justify-content:center}.default-home .stat-card .stat-icon svg{width:24px;height:24px}.default-home .stat-card.stat-card-inline{cursor:default;text-decoration:none;pointer-events:none}.default-home .stat-card.stat-card-inline .stat-value{font-size:1.1rem}.default-home-actions .quick-links{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem}.default-home-actions .quick-link-card{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.25rem 1rem;background:var(--榕树浅绿);border:1px solid rgba(76,175,80,.2);border-radius:var(--radius-md);color:var(--榕树深绿);text-decoration:none;font-weight:500;transition:transform .2s ease,box-shadow .2s ease;min-height:80px;justify-content:center}.default-home-actions .quick-link-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.default-home-actions .quick-link-card:active{transform:translateY(0)}.default-home-actions .quick-link-icon{font-size:1.5rem;display:flex;align-items:center;justify-content:center}.default-home-actions .quick-link-icon svg{width:26px;height:26px}.default-home-actions .quick-link-text{font-size:.9rem}.role-home .progress-row{display:flex;align-items:center;gap:.75rem;margin-top:1rem;flex-wrap:wrap}.role-home .progress-row span{min-width:6rem;font-size:.875rem;color:var(--text-secondary)}.role-home .progress-bar-wrap{flex:1;min-width:120px;height:12px;background:#e0e0e0;border-radius:6px;overflow:hidden;display:flex}.role-home .progress-bar{height:100%;min-width:4px;transition:width .3s}.role-home .stat-note{margin-top:.5rem;font-size:.875rem;color:var(--text-secondary)}.role-home .pending-list{list-style:none}.role-home .pending-list li{display:flex;align-items:center;justify-content:space-between;padding:.6rem 0;border-bottom:1px solid var(--border-color);gap:.5rem}.role-home .pending-list a{color:var(--secondary-color);text-decoration:none;flex:1}.role-home .pending-list a:hover{text-decoration:underline}.role-home .badge.pending{background:#ffa726;color:#fff;padding:.2rem .5rem;border-radius:6px;font-size:.75rem}.role-home .link-more{display:inline-block;margin-top:.5rem;color:var(--榕树绿色);font-size:.875rem}.role-home .empty-message{color:var(--text-light);font-style:italic;padding:.5rem 0}.role-home .quick-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1rem}.role-home .quick-actions a{padding:.5rem 1rem;background:var(--榕树浅绿);color:var(--榕树深绿);border-radius:8px;text-decoration:none}.role-home .quick-action-card{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.25rem;background:var(--榕树浅绿);border-radius:12px;text-decoration:none;color:var(--榕树深绿);min-width:100px;transition:transform .2s}.role-home .quick-action-card:hover{transform:translateY(-2px)}.role-home .quick-icon{font-size:1.5rem;display:flex;align-items:center;justify-content:center}.role-home .quick-icon svg{width:26px;height:26px}.role-home .backup-status .backup-info{display:flex;flex-direction:column;gap:.5rem}.role-home .backup-row{display:flex;justify-content:space-between;padding:.4rem 0}.role-home .alerts .alert-list .alert-item.ok{color:var(--榕树深绿);padding:.5rem}.role-home .two-cols{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.role-home .two-cols .col h2{font-size:1rem}.admin-home-shell .dashboard-section{box-shadow:var(--shadow-md);border-color:#4caf5024}.admin-home-hero{position:relative;display:grid;grid-template-columns:minmax(0,1.55fr) minmax(280px,1fr);gap:1rem;margin-bottom:var(--space-lg);padding:clamp(1.25rem,2vw,2rem);border-radius:24px;overflow:hidden;background:linear-gradient(135deg,#1f6b3b,#2e7d32 48%,#66bb6a);box-shadow:var(--shadow-lg);color:#fff}.admin-home-hero:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at top right,rgba(255,255,255,.24),transparent 38%),radial-gradient(circle at bottom left,rgba(255,255,255,.16),transparent 30%);pointer-events:none}.admin-home-hero-main,.admin-home-focus-card{position:relative;z-index:1}.admin-home-kicker{margin-bottom:.45rem;font-size:.82rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#ffffffd1}.admin-home-hero h1{margin-bottom:.6rem;color:#fff}.admin-home-subtitle{max-width:48rem;font-size:.98rem;color:#ffffffe6}.admin-home-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.admin-home-chip{display:inline-flex;align-items:center;padding:.4rem .8rem;border:1px solid rgba(255,255,255,.2);border-radius:999px;background:#ffffff24;color:#fff;font-size:.86rem}.admin-home-hero-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.25rem}.admin-home-hero .primary-button{background:#ffffff29;border:1px solid rgba(255,255,255,.22);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.admin-home-hero .primary-button.outline{background:#fff;color:var(--primary-dark);border-color:#fff}.admin-home-focus-card{display:flex;flex-direction:column;justify-content:space-between;padding:1rem;border:1px solid rgba(255,255,255,.16);border-radius:18px;background:#ffffff24;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.admin-home-focus-title{font-size:.88rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#fffc}.admin-home-focus-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;margin-top:1rem}.admin-home-focus-item{padding:.9rem;border:1px solid rgba(255,255,255,.08);border-radius:14px;background:#ffffff1a}.admin-home-focus-label{display:block;font-size:.78rem;color:#ffffffc2}.admin-home-focus-value{display:block;margin-top:.35rem;font-size:1.2rem;font-weight:700;color:#fff}.admin-home-stat-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.admin-home-stat-card{position:relative;overflow:hidden;gap:.35rem}.admin-home-stat-card:before{content:"";position:absolute;left:0;right:0;bottom:0;height:4px;background:linear-gradient(90deg,#4caf50d9,#2196f3bf)}.admin-home-stat-helper{font-size:.78rem;color:var(--text-light)}.admin-home-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.25rem;margin-bottom:var(--space-lg)}.admin-home-section-muted{margin-top:-.35rem;margin-bottom:1rem;color:var(--text-secondary);font-size:.92rem}.admin-home-queue-list{list-style:none;display:flex;flex-direction:column;gap:.75rem}.admin-home-queue-item{display:flex;justify-content:space-between;gap:1rem;padding:1rem;border:1px solid rgba(76,175,80,.12);border-radius:16px;background:linear-gradient(180deg,#fcfffc,#f7fbf7)}.admin-home-queue-main{min-width:0;display:flex;flex-direction:column;gap:.25rem}.admin-home-queue-title{color:var(--secondary-dark);font-weight:600;text-decoration:none}.admin-home-queue-title:hover{text-decoration:underline}.admin-home-queue-meta{color:var(--text-secondary);font-size:.88rem}.admin-home-queue-side{display:flex;flex-direction:column;align-items:flex-end;gap:.45rem;flex-shrink:0}.admin-home-queue-aux{font-size:.88rem;font-weight:700;color:var(--primary-dark)}.admin-home-action-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem}.admin-home-action-card{--admin-accent: #90a4ae;position:relative;display:flex;flex-direction:column;gap:.4rem;min-height:124px;padding:1rem;overflow:hidden;border:1px solid var(--border-color);border-radius:18px;background:linear-gradient(180deg,#fff,#f8faf8);color:inherit;text-decoration:none;box-shadow:0 1px 2px #00000008;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.admin-home-action-card:after{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--admin-accent)}.admin-home-action-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:#4caf5047}.admin-home-action-card.tone-info{--admin-accent: var(--secondary-color)}.admin-home-action-card.tone-success{--admin-accent: var(--primary-color)}.admin-home-action-card.tone-warning{--admin-accent: var(--accent-color)}.admin-home-action-title{font-size:1rem;font-weight:600;color:var(--text-primary)}.admin-home-action-meta{font-size:.85rem;color:var(--text-secondary)}.admin-home-action-value{margin-top:auto;font-size:1.3rem;font-weight:700;color:var(--admin-accent)}.admin-home-mini-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.85rem;margin-top:1rem}.admin-home-mini-card{padding:.85rem .95rem;border:1px solid rgba(76,175,80,.1);border-radius:14px;background:var(--background-light)}.admin-home-mini-label{display:block;font-size:.8rem;color:var(--text-secondary)}.admin-home-mini-value{display:block;margin-top:.35rem;font-size:1rem;font-weight:700;color:var(--primary-dark)}.audit-dashboard{padding:1rem 0 2rem}.audit-dashboard .dashboard-section{border-color:#4caf5024;box-shadow:var(--shadow-md)}.audit-dashboard .empty-message{margin:0;padding:1.25rem;border:1px dashed rgba(76,175,80,.2);border-radius:16px;background:linear-gradient(180deg,#fbfefb,#f4f8f4)}.audit-hero{position:relative;display:grid;grid-template-columns:minmax(0,1.3fr) minmax(280px,1fr);gap:1rem;margin-bottom:1.25rem;padding:clamp(1.2rem,2vw,1.8rem);overflow:hidden;border-radius:24px;background:linear-gradient(135deg,#234a7c,#2e7d32,#4caf50);box-shadow:var(--shadow-lg);color:#fff}.audit-hero:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 100% 0%,rgba(255,255,255,.22),transparent 34%),radial-gradient(circle at 0% 100%,rgba(255,255,255,.14),transparent 28%);pointer-events:none}.audit-hero-main,.audit-hero-stats{position:relative;z-index:1}.audit-hero-kicker{margin-bottom:.45rem;font-size:.82rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#fffc}.audit-hero h1{margin-bottom:.6rem;color:#fff}.audit-hero-subtitle{max-width:44rem;color:#ffffffe6;font-size:.98rem}.audit-hero-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}.audit-hero-stat{padding:.95rem 1rem;border:1px solid rgba(255,255,255,.12);border-radius:18px;background:#ffffff1f;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.audit-hero-stat span{display:block;font-size:.8rem;color:#ffffffc7}.audit-hero-stat strong{display:block;margin-top:.35rem;font-size:1.35rem;font-weight:700;color:#fff}.audit-inline-error{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.25rem;padding:1rem 1.1rem;border:1px solid rgba(211,47,47,.18);border-radius:16px;background:#f4433614;color:var(--error-dark)}.audit-inline-error-main{min-width:0}.audit-panel-primary{margin-bottom:1.25rem}.audit-panel-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.25rem}.audit-panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem}.audit-panel-header h2{margin-bottom:.25rem;border-bottom:none;padding-bottom:0}.audit-panel-subtitle{color:var(--text-secondary);font-size:.92rem}.audit-card-list{display:flex;flex-direction:column;gap:1rem}.audit-card{position:relative;overflow:hidden;padding:1rem;border:1px solid rgba(76,175,80,.12);border-radius:18px;background:linear-gradient(180deg,#fff,#f9fcf9);box-shadow:0 8px 20px #0000000d}.audit-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:#4caf5059}.audit-card-pending:before{background:#ff9800cc}.audit-card-approved:before{background:#4caf50d1}.audit-card-rejected:before{background:#f44336d1}.audit-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.audit-card-heading{min-width:0}.audit-card-heading h3{margin-bottom:0;color:var(--text-primary);font-size:1.02rem;font-weight:700}.audit-card-subline{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.55rem}.audit-code-pill,.audit-meta-pill,.audit-card-info{display:inline-flex;align-items:center;padding:.38rem .68rem;border:1px solid rgba(76,175,80,.14);border-radius:999px;background:#4caf500f;color:var(--text-secondary);font-size:.82rem}.audit-card-goal{margin-top:1rem;padding:.95rem 1rem;border:1px solid rgba(33,150,243,.08);border-radius:14px;background:linear-gradient(180deg,#2196f30d,#2196f305);color:var(--text-secondary)}.audit-card-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem;margin-top:1rem}.audit-mini-metric{padding:.85rem .95rem;border-radius:14px;background:var(--background-light);border:1px solid rgba(76,175,80,.08)}.audit-mini-metric span{display:block;font-size:.78rem;color:var(--text-secondary)}.audit-mini-metric strong{display:block;margin-top:.35rem;font-size:1rem;font-weight:700;color:var(--primary-dark)}.audit-card-block{margin-top:1rem}.audit-card-block h4{margin-bottom:.7rem;color:var(--text-primary);font-size:.92rem;font-weight:700}.audit-inline-empty{color:var(--text-light);font-size:.9rem}.audit-auditor-list,.audit-member-list{list-style:none;display:flex;flex-direction:column;gap:.65rem}.audit-auditor-item,.audit-member-item{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.85rem .95rem;border:1px solid rgba(76,175,80,.08);border-radius:14px;background:#fff}.audit-auditor-main{min-width:0;display:flex;flex-direction:column;gap:.2rem}.audit-auditor-meta,.audit-member-work{color:var(--text-secondary);font-size:.82rem}.audit-dashboard .auditor-name{font-size:.92rem;font-weight:600;color:var(--text-primary)}.audit-dashboard .status-badge,.audit-dashboard .audit-status-badge{display:inline-flex;align-items:center;justify-content:center;padding:.35rem .7rem;border-radius:999px;font-size:.76rem;font-weight:700}.audit-dashboard .status-badge.pending,.audit-dashboard .audit-status-badge.pending{background:#ff98001f;border:1px solid rgba(255,152,0,.22);color:var(--accent-dark)}.audit-dashboard .status-badge.approved,.audit-dashboard .audit-status-badge.approved{background:#4caf501f;border:1px solid rgba(76,175,80,.22);color:var(--primary-dark)}.audit-dashboard .status-badge.rejected,.audit-dashboard .audit-status-badge.rejected{background:#f443361f;border:1px solid rgba(244,67,54,.22);color:var(--error-dark)}.audit-member-item{align-items:flex-start;flex-wrap:wrap}.audit-member-role{display:inline-flex;align-items:center;padding:.25rem .55rem;border-radius:999px;background:#2196f314;color:var(--secondary-dark);font-size:.76rem;font-weight:700}.audit-member-role.leader{background:#4caf501f;color:var(--primary-dark)}.audit-member-name,.audit-member-share{font-weight:600;color:var(--text-primary)}.audit-card-actions{display:flex;gap:.75rem;margin-top:1rem}.audit-card-info-list{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:1rem}.audit-card-alert{display:flex;flex-direction:column;gap:.35rem;margin-top:1rem;padding:.9rem 1rem;border-radius:14px}.audit-card-alert.rejected{background:#f4433614;border:1px solid rgba(244,67,54,.12);color:var(--error-dark)}.audit-reject-shell .form-group textarea{width:100%;min-height:120px;padding:.9rem 1rem;border:1px solid var(--border-color);border-radius:14px;background:#fff}.audit-dashboard .approve-button,.audit-dashboard .reject-button,.audit-dashboard .cancel-button,.audit-dashboard .submit-button{border-radius:12px}.audit-dashboard .approve-button:disabled,.audit-dashboard .reject-button:disabled,.audit-dashboard .cancel-button:disabled,.audit-dashboard .submit-button:disabled{opacity:.65;cursor:not-allowed;transform:none}@media(max-width:900px){.admin-home-hero,.admin-home-grid,.audit-hero,.audit-panel-grid{grid-template-columns:1fr}}@media(max-width:767px){.admin-home-action-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-home-queue-item{flex-direction:column;align-items:flex-start}.admin-home-queue-side{align-items:flex-start}.audit-hero-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.audit-inline-error,.audit-card-top,.audit-card-actions,.audit-auditor-item{flex-direction:column;align-items:flex-start}.audit-card-actions .approve-button,.audit-card-actions .reject-button{width:100%}}@media(max-width:560px){.admin-home-hero{padding:1.25rem;border-radius:18px}.admin-home-focus-grid,.admin-home-action-grid,.admin-home-mini-grid{grid-template-columns:1fr}.audit-hero{padding:1.2rem;border-radius:18px}.audit-hero-stats,.audit-card-metrics{grid-template-columns:1fr}}@media(max-width:767px){.role-home .stat-cards{grid-template-columns:repeat(2,1fr)}.role-home .stat-cards.small{grid-template-columns:repeat(3,1fr)}.default-home-actions .quick-links{grid-template-columns:1fr}.default-home-actions .quick-link-card{min-height:56px;flex-direction:row}.default-home-actions .quick-link-icon{font-size:1.25rem}.role-home .two-cols{grid-template-columns:1fr}.role-home .page-header{flex-direction:column;align-items:flex-start}}.loading{text-align:center;padding:var(--space-2xl) var(--space-lg);color:var(--text-secondary);font-size:1rem;min-height:120px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:var(--space-md)}.loading:before{content:"";width:32px;height:32px;border:3px solid var(--border-color);border-top-color:var(--榕树绿色);border-radius:50%;animation:ui-spin .8s linear infinite}@keyframes ui-spin{to{transform:rotate(360deg)}}.home-loading{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:var(--space-2xl);box-sizing:border-box}.home-loading__inner{display:flex;flex-direction:column;align-items:center;gap:var(--space-xl);max-width:360px;text-align:center}.home-loading__spinner{width:48px;height:48px;border:4px solid var(--border-color);border-top-color:var(--榕树绿色);border-radius:50%;animation:ui-spin .85s linear infinite;flex-shrink:0}.home-loading__text{margin:0;color:var(--text-primary);font-size:1.0625rem;font-weight:500;letter-spacing:.02em;line-height:1.5}.home-loading__text--secondary{color:var(--text-secondary);font-size:.9375rem;font-weight:400}@media(max-width:768px){.home-loading{min-height:50vh;padding:var(--space-xl)}.home-loading__spinner{width:40px;height:40px;border-width:3px}.home-loading__text{font-size:1rem}.home-loading__text--secondary{font-size:.875rem}}.error-message{background:#ffebee;color:var(--error-dark);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);border-left:4px solid var(--error-color);font-size:.9375rem}.retry-button{padding:var(--space-sm) var(--space-md);background:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-sm);font-weight:500;cursor:pointer;font-size:.875rem;transition:background .2s ease,transform .15s ease}.retry-button:hover{background:var(--primary-dark);transform:translateY(-1px)}@media(min-width:768px)and (max-width:1024px){.main-content{padding:var(--space-xl) var(--space-lg);padding-bottom:calc(var(--nav-height) + var(--space-lg))}.page{padding:0 var(--space-md)}}@media(max-width:767px){.main-content{padding:var(--space-md);padding-bottom:calc(var(--nav-height) + var(--space-md))}.page{padding:0 var(--space-sm)}.page-header h1{font-size:1.2rem}}@media(max-width:480px){.main-content{padding:var(--space-sm);padding-bottom:calc(var(--nav-height) + var(--space-sm))}.header-content{padding:0}.app-title{font-size:1.1rem}}.card,.project-card,.expense-card{border-radius:var(--radius-lg);box-shadow:var(--shadow);border:1px solid var(--border-color);transition:box-shadow .2s ease,border-color .2s ease}.card:hover,.project-card:hover,.expense-card:hover{box-shadow:var(--shadow-md);border-color:var(--榕树浅绿)}.sidebar{box-shadow:var(--shadow-lg);border-radius:0 var(--radius-lg) var(--radius-lg) 0}.sidebar.open{box-shadow:8px 0 24px #0000001f}input[type=text],input[type=number],input[type=date],input[type=password],select,textarea{border-radius:var(--radius-sm);border:1px solid var(--border-color);transition:border-color .2s ease,box-shadow .2s ease}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--榕树绿色);box-shadow:0 0 0 3px #4caf5026}.profile-page,.admin-profile-page,.super-admin-profile-page{max-width:1240px;margin:0 auto;display:flex;flex-direction:column;gap:18px}.profile-page .profile-page-header,.admin-profile-page .profile-page-header,.super-admin-profile-page .profile-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:0}.profile-page .profile-content,.admin-profile-page .profile-content,.super-admin-profile-page .profile-content{display:flex;flex-direction:column;gap:20px}.profile-page .profile-main-grid,.admin-profile-page .profile-main-grid,.super-admin-profile-page .profile-main-grid{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(300px,.85fr);gap:20px;align-items:start}.profile-page .profile-section-card,.admin-profile-page .profile-section-card,.super-admin-profile-page .profile-section-card{background:#fffffff2;border:1px solid rgba(255,255,255,.78);border-radius:24px;padding:24px;box-shadow:var(--shadow-md)}.profile-page .profile-hero-card,.admin-profile-page .profile-hero-card,.super-admin-profile-page .profile-hero-card{position:relative;overflow:hidden;display:grid;grid-template-columns:auto 1fr;align-items:center;gap:22px;margin:0;padding:28px;border-radius:28px;border:none;background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary-color) 58%,#7cb342 100%);color:#fff;box-shadow:var(--shadow-lg)}.profile-page .profile-hero-card:before,.profile-page .profile-hero-card:after,.admin-profile-page .profile-hero-card:before,.admin-profile-page .profile-hero-card:after,.super-admin-profile-page .profile-hero-card:before,.super-admin-profile-page .profile-hero-card:after{content:"";position:absolute;border-radius:999px;background:#ffffff1a;pointer-events:none}.profile-page .profile-hero-card:before,.admin-profile-page .profile-hero-card:before,.super-admin-profile-page .profile-hero-card:before{width:240px;height:240px;top:-110px;right:-40px}.profile-page .profile-hero-card:after,.admin-profile-page .profile-hero-card:after,.super-admin-profile-page .profile-hero-card:after{width:150px;height:150px;bottom:-48px;right:120px}.profile-page .profile-hero-card .avatar-container,.admin-profile-page .profile-hero-card .avatar-container,.super-admin-profile-page .profile-hero-card .avatar-container{width:116px;height:116px;margin:0;border:4px solid rgba(255,255,255,.95);box-shadow:0 12px 24px #00000029}.profile-page .profile-hero-card .avatar-placeholder,.admin-profile-page .profile-hero-card .avatar-placeholder,.super-admin-profile-page .profile-hero-card .avatar-placeholder{background:linear-gradient(135deg,#ffffff38,#ffffff1a);color:#fff;font-size:44px}.profile-page .profile-identity,.admin-profile-page .profile-identity,.super-admin-profile-page .profile-identity{position:relative;z-index:1;min-width:0}.profile-page .profile-identity .profile-name,.admin-profile-page .profile-identity .profile-name,.super-admin-profile-page .profile-identity .profile-name{margin:0;color:#fff;font-size:32px;font-weight:800;text-align:left}.profile-page .profile-identity .profile-role-text,.admin-profile-page .profile-identity .profile-role-text,.super-admin-profile-page .profile-identity .profile-role-text{margin-top:8px;color:#ffffffe6;font-size:15px;font-weight:500}.profile-page .profile-meta-row,.profile-page .profile-role-chips,.admin-profile-page .profile-meta-row,.admin-profile-page .profile-role-chips,.super-admin-profile-page .profile-meta-row,.super-admin-profile-page .profile-role-chips{display:flex;flex-wrap:wrap;gap:10px}.profile-page .profile-meta-row,.admin-profile-page .profile-meta-row,.super-admin-profile-page .profile-meta-row{margin-top:16px}.profile-page .profile-role-chips,.admin-profile-page .profile-role-chips,.super-admin-profile-page .profile-role-chips{margin-top:12px}.profile-page .profile-meta-chip,.profile-page .profile-role-chip,.admin-profile-page .profile-meta-chip,.admin-profile-page .profile-role-chip,.super-admin-profile-page .profile-meta-chip,.super-admin-profile-page .profile-role-chip{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:6px 12px;border-radius:999px;font-size:12px;font-weight:700}.profile-page .profile-meta-chip,.admin-profile-page .profile-meta-chip,.super-admin-profile-page .profile-meta-chip{background:#ffffff24;border:1px solid rgba(255,255,255,.2);color:#fff}.profile-page .profile-role-chip,.admin-profile-page .profile-role-chip,.super-admin-profile-page .profile-role-chip{background:#0f172a2e;border:1px solid rgba(255,255,255,.18);color:#fff}.profile-page .profile-info,.admin-profile-page .profile-info,.super-admin-profile-page .profile-info,.profile-page .profile-stats,.admin-profile-page .profile-stats,.super-admin-profile-page .profile-stats{margin:0;background:#fffffff2;border:1px solid rgba(255,255,255,.78);box-shadow:var(--shadow-md)}.profile-page .profile-info:before,.admin-profile-page .profile-info:before,.super-admin-profile-page .profile-info:before{display:none}.profile-page .profile-info .info-item,.admin-profile-page .profile-info .info-item,.super-admin-profile-page .profile-info .info-item{display:grid;grid-template-columns:140px minmax(0,1fr);gap:16px;align-items:start;margin:0;padding:16px 0;border-bottom:1px solid rgba(15,23,42,.06)}.profile-page .profile-info .info-item:last-child,.admin-profile-page .profile-info .info-item:last-child,.super-admin-profile-page .profile-info .info-item:last-child{border-bottom:none;padding-bottom:0}.profile-page .profile-info .info-item:first-child,.admin-profile-page .profile-info .info-item:first-child,.super-admin-profile-page .profile-info .info-item:first-child{padding-top:0}.profile-page .profile-info .info-item:hover,.admin-profile-page .profile-info .info-item:hover,.super-admin-profile-page .profile-info .info-item:hover{background:transparent;padding-left:0;border-left:none;border-radius:0;transform:none}.profile-page .profile-info .info-item label,.admin-profile-page .profile-info .info-item label,.super-admin-profile-page .profile-info .info-item label{margin:0;font-size:13px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.profile-page .profile-info .info-item label:before,.admin-profile-page .profile-info .info-item label:before,.super-admin-profile-page .profile-info .info-item label:before{content:none}.profile-page .profile-info .info-item span,.profile-page .profile-info .info-item p,.admin-profile-page .profile-info .info-item span,.admin-profile-page .profile-info .info-item p,.super-admin-profile-page .profile-info .info-item span,.super-admin-profile-page .profile-info .info-item p{margin:0;min-height:52px;padding:14px 16px;border-radius:16px;border:1px solid rgba(15,23,42,.06);background:linear-gradient(180deg,#fafbfcfa,#f5f8fafa);box-shadow:none;color:var(--text-primary);font-weight:500;display:flex;align-items:center}.profile-page .profile-info .info-item p,.admin-profile-page .profile-info .info-item p,.super-admin-profile-page .profile-info .info-item p{align-items:flex-start}.profile-page .profile-stats h2,.admin-profile-page .profile-stats h2,.super-admin-profile-page .profile-stats h2{margin:0 0 18px;padding:0;border:none;font-size:18px;color:var(--text-primary)}.profile-page .profile-stats h2:before,.admin-profile-page .profile-stats h2:before,.super-admin-profile-page .profile-stats h2:before{content:none}.profile-page .profile-stats .stats-grid,.admin-profile-page .profile-stats .stats-grid,.super-admin-profile-page .profile-stats .stats-grid{grid-template-columns:1fr;gap:14px}.profile-page .profile-stats .stat-card,.admin-profile-page .profile-stats .stat-card,.super-admin-profile-page .profile-stats .stat-card{padding:18px 20px;border-radius:18px;border:1px solid rgba(76,175,80,.1);background:linear-gradient(180deg,#f8fcf4f5,#eef7eeeb);box-shadow:none;text-align:left}.profile-page .profile-stats .stat-card:before,.admin-profile-page .profile-stats .stat-card:before,.super-admin-profile-page .profile-stats .stat-card:before{width:100%;height:5px;top:0;left:0;border-radius:18px 18px 0 0}.profile-page .profile-stats .stat-card:after,.admin-profile-page .profile-stats .stat-card:after,.super-admin-profile-page .profile-stats .stat-card:after{top:-20px;right:-20px;bottom:auto;width:86px;height:86px;opacity:.16}.profile-page .profile-stats .stat-card h3,.admin-profile-page .profile-stats .stat-card h3,.super-admin-profile-page .profile-stats .stat-card h3{justify-content:flex-start;margin-bottom:10px;color:var(--text-secondary);font-size:14px}.profile-page .profile-stats .stat-card .stat-value,.admin-profile-page .profile-stats .stat-card .stat-value,.super-admin-profile-page .profile-stats .stat-card .stat-value{margin:0;color:var(--primary-dark);font-size:28px;font-weight:800;line-height:1.1}.profile-page .profile-completion-banner,.admin-profile-page .profile-completion-banner{margin-bottom:0;border-radius:18px;border-left:none;box-shadow:var(--shadow)}.profile-page .avatar-error,.admin-profile-page .avatar-error,.super-admin-profile-page .avatar-error{color:var(--error-color);font-size:14px;margin:0 0 10px}.profile-page .profile-form-modern,.admin-profile-page .profile-form-modern,.super-admin-profile-page .profile-form-modern{margin-bottom:0;padding:24px;border:none;border-radius:24px;box-shadow:var(--shadow-lg);background:#fffffff5}.profile-page .profile-form-layout,.admin-profile-page .profile-form-layout,.super-admin-profile-page .profile-form-layout{display:grid;grid-template-columns:minmax(240px,300px) minmax(0,1fr);gap:22px;align-items:start}.profile-page .profile-form-aside,.admin-profile-page .profile-form-aside,.super-admin-profile-page .profile-form-aside{position:sticky;top:84px}.profile-page .profile-form-aside .form-group,.admin-profile-page .profile-form-aside .form-group,.super-admin-profile-page .profile-form-aside .form-group{margin:0}.profile-page .profile-form-aside .avatar-upload,.admin-profile-page .profile-form-aside .avatar-upload,.super-admin-profile-page .profile-form-aside .avatar-upload{padding:24px 20px;border-radius:20px;background:linear-gradient(180deg,#f8fcf4fa,#eef7eef0);border:1px solid rgba(76,175,80,.12)}.profile-page .profile-form-aside .avatar-preview,.admin-profile-page .profile-form-aside .avatar-preview,.super-admin-profile-page .profile-form-aside .avatar-preview{width:144px;height:144px;border:4px solid #fff}.profile-page .profile-form-aside .avatar-placeholder,.admin-profile-page .profile-form-aside .avatar-placeholder,.super-admin-profile-page .profile-form-aside .avatar-placeholder{background:linear-gradient(135deg,#e8f5e9e6,#a5d6a7e6);color:var(--text-secondary);font-size:14px}.profile-page .profile-form-fields,.admin-profile-page .profile-form-fields,.super-admin-profile-page .profile-form-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;align-items:start}.profile-page .profile-form-fields .form-group,.admin-profile-page .profile-form-fields .form-group,.super-admin-profile-page .profile-form-fields .form-group{margin-bottom:0}.profile-page .profile-form-fields .form-group.form-group-full,.admin-profile-page .profile-form-fields .form-group.form-group-full,.super-admin-profile-page .profile-form-fields .form-group.form-group-full{grid-column:1 / -1}.profile-page .profile-form-modern .form-group label,.admin-profile-page .profile-form-modern .form-group label,.super-admin-profile-page .profile-form-modern .form-group label{margin-bottom:10px;color:var(--text-primary);font-size:14px;font-weight:600}.profile-page .profile-form-modern input:not([type=file]),.profile-page .profile-form-modern textarea,.admin-profile-page .profile-form-modern input:not([type=file]),.admin-profile-page .profile-form-modern textarea,.super-admin-profile-page .profile-form-modern input:not([type=file]),.super-admin-profile-page .profile-form-modern textarea{width:100%;min-height:50px;padding:12px 14px;border-radius:14px;border:1px solid rgba(15,23,42,.1);background:#fff}.profile-page .profile-form-modern textarea,.admin-profile-page .profile-form-modern textarea,.super-admin-profile-page .profile-form-modern textarea{min-height:118px;resize:vertical}.profile-page .password-input-wrap,.admin-profile-page .password-input-wrap,.super-admin-profile-page .password-input-wrap{position:relative}.profile-page .password-input-wrap input,.admin-profile-page .password-input-wrap input,.super-admin-profile-page .password-input-wrap input{padding-right:52px}.profile-page .password-toggle-btn,.admin-profile-page .password-toggle-btn,.super-admin-profile-page .password-toggle-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:36px;height:36px;border:none;border-radius:10px;background:#4caf501a;color:var(--primary-dark);cursor:pointer;transition:background-color .2s ease,transform .2s ease}.profile-page .password-toggle-btn:hover,.admin-profile-page .password-toggle-btn:hover,.super-admin-profile-page .password-toggle-btn:hover{background:#4caf5029}.profile-page .profile-submit-row,.admin-profile-page .profile-submit-row,.super-admin-profile-page .profile-submit-row{grid-column:1 / -1;display:flex;justify-content:flex-end;padding-top:6px}.profile-page .profile-submit-row .submit-button,.admin-profile-page .profile-submit-row .submit-button,.super-admin-profile-page .profile-submit-row .submit-button{min-width:170px;padding:12px 22px;border-radius:14px;font-weight:700}@media(max-width:960px){.profile-page .profile-main-grid,.admin-profile-page .profile-main-grid,.super-admin-profile-page .profile-main-grid,.profile-page .profile-form-layout,.admin-profile-page .profile-form-layout,.super-admin-profile-page .profile-form-layout{grid-template-columns:1fr}.profile-page .profile-form-aside,.admin-profile-page .profile-form-aside,.super-admin-profile-page .profile-form-aside{position:static}}@media(max-width:767px){.profile-page .profile-page-header,.admin-profile-page .profile-page-header,.super-admin-profile-page .profile-page-header{flex-direction:column;align-items:stretch}.profile-page .profile-hero-card,.admin-profile-page .profile-hero-card,.super-admin-profile-page .profile-hero-card{grid-template-columns:1fr;justify-items:center;text-align:center;padding:24px 20px}.profile-page .profile-identity .profile-name,.admin-profile-page .profile-identity .profile-name,.super-admin-profile-page .profile-identity .profile-name{text-align:center;font-size:28px}.profile-page .profile-meta-row,.profile-page .profile-role-chips,.admin-profile-page .profile-meta-row,.admin-profile-page .profile-role-chips,.super-admin-profile-page .profile-meta-row,.super-admin-profile-page .profile-role-chips{justify-content:center}.profile-page .profile-form-fields,.admin-profile-page .profile-form-fields,.super-admin-profile-page .profile-form-fields{grid-template-columns:1fr}.profile-page .profile-info .info-item,.admin-profile-page .profile-info .info-item,.super-admin-profile-page .profile-info .info-item{grid-template-columns:1fr;gap:10px}}@media(max-width:480px){.profile-page .profile-hero-card .avatar-container,.admin-profile-page .profile-hero-card .avatar-container,.super-admin-profile-page .profile-hero-card .avatar-container{width:96px;height:96px}.profile-page .profile-identity .profile-name,.admin-profile-page .profile-identity .profile-name,.super-admin-profile-page .profile-identity .profile-name{font-size:24px}.profile-page .profile-section-card,.admin-profile-page .profile-section-card,.super-admin-profile-page .profile-section-card,.profile-page .profile-form-modern,.admin-profile-page .profile-form-modern,.super-admin-profile-page .profile-form-modern{padding:18px;border-radius:20px}.profile-page .profile-submit-row .submit-button,.admin-profile-page .profile-submit-row .submit-button,.super-admin-profile-page .profile-submit-row .submit-button{width:100%}}
