*{box-sizing:border-box;margin:0;padding:0}body{color:#3a3530;background:#f5f2ed;font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Helvetica Neue,sans-serif}#root{height:100vh;overflow:hidden}.login-bg{background:linear-gradient(135deg,#f5f2ed 0%,#ede8e0 50%,#e5dfd5 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:#fff;border-radius:20px;width:400px;padding:48px 44px 40px;box-shadow:0 8px 48px #3a35301f}.login-logo{align-items:center;gap:10px;margin-bottom:32px;display:flex}.login-logo-icon{background:linear-gradient(135deg,#8b9e8a,#6b8a6a);border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;display:flex}.login-logo-text{color:#3a3530;font-size:18px;font-weight:800}.login-logo-sub{color:#a8a09a;margin-top:1px;font-size:12px}.login-title{color:#3a3530;margin-bottom:6px;font-size:22px;font-weight:800}.login-subtitle{color:#a8a09a;margin-bottom:28px;font-size:13px}.login-field{margin-bottom:16px}.login-field label{color:#5a5450;margin-bottom:7px;font-size:12px;font-weight:600;display:block}.login-field input{color:#3a3530;border:1.5px solid #e0ddd6;border-radius:10px;outline:none;width:100%;padding:11px 14px;font-family:inherit;font-size:14px;transition:border .2s}.login-field input:focus{border-color:#8b9e8a}.login-field .pw-wrap{position:relative}.login-field .pw-eye{cursor:pointer;color:#a8a09a;-webkit-user-select:none;user-select:none;font-size:16px;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.login-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#8b9e8a,#6b8a6a);border:none;border-radius:10px;width:100%;margin-top:8px;padding:13px;font-family:inherit;font-size:15px;font-weight:700;transition:opacity .2s}.login-btn:hover{opacity:.88}.login-btn:disabled{opacity:.55;cursor:not-allowed}.login-error{color:#9a5550;background:#fef2f0;border:1px solid #f5c4bb;border-radius:8px;margin-bottom:16px;padding:10px 14px;font-size:13px}.login-footer{text-align:center;color:#c0bab4;margin-top:24px;font-size:11px}.settings-overlay{z-index:2000;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.settings-panel{background:#fff;border-radius:18px;flex-direction:column;width:520px;max-width:94vw;max-height:88vh;display:flex;overflow:hidden;box-shadow:0 12px 60px #0000002e}.settings-header{flex-shrink:0;justify-content:space-between;align-items:center;padding:22px 26px 0;display:flex}.settings-header-title{color:#3a3530;font-size:17px;font-weight:800}.settings-close{cursor:pointer;color:#7a736e;background:#f0ede6;border:none;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;font-size:18px;display:flex}.settings-tabs{border-bottom:1.5px solid #f0ede6;flex-shrink:0;gap:0;margin-top:18px;padding:0 26px;display:flex}.settings-tab{cursor:pointer;color:#a8a09a;white-space:nowrap;border-bottom:2.5px solid #0000;margin-bottom:-1.5px;padding:9px 18px;font-size:13px;font-weight:600;transition:all .15s}.settings-tab.active{color:#4f7a5a;border-bottom-color:#8b9e8a}.settings-body{flex:1;padding:24px 26px;overflow-y:auto}.settings-field{margin-bottom:18px}.settings-field label{color:#5a5450;align-items:center;gap:6px;margin-bottom:7px;font-size:12px;font-weight:600;display:flex}.settings-field label span.hint{color:#a8a09a;font-size:11px;font-weight:400}.settings-field input,.settings-field select{color:#3a3530;background:#fff;border:1.5px solid #e0ddd6;border-radius:9px;outline:none;width:100%;padding:10px 13px;font-family:inherit;font-size:13px;transition:border .2s}.settings-field input:focus,.settings-field select:focus{border-color:#8b9e8a}.settings-field .pw-wrap{position:relative}.settings-field .pw-wrap input{padding-right:40px}.settings-field .pw-eye{cursor:pointer;color:#a8a09a;-webkit-user-select:none;user-select:none;font-size:15px;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.settings-divider{background:#f0ede6;height:1px;margin:20px 0}.settings-section-title{color:#c0bab4;letter-spacing:.05em;text-transform:uppercase;margin-bottom:14px;font-size:11px;font-weight:700}.settings-footer{border-top:1px solid #f0ede6;flex-shrink:0;justify-content:flex-end;gap:10px;padding:16px 26px;display:flex}.settings-status{flex:1;align-items:center;gap:6px;font-size:12px;display:flex}.status-dot{border-radius:50%;width:7px;height:7px}.btn-primary{color:#fff;cursor:pointer;background:#8b9e8a;border:none;border-radius:8px;padding:9px 20px;font-family:inherit;font-size:13px;font-weight:700;transition:opacity .2s}.btn-primary:hover{opacity:.85}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{color:#7a736e;cursor:pointer;background:#fff;border:1.5px solid #e0ddd6;border-radius:8px;padding:9px 16px;font-family:inherit;font-size:13px;font-weight:600;transition:opacity .2s}.btn-ghost:hover{opacity:.8}.btn-danger{color:#9a5550;cursor:pointer;background:#fef2f0;border:1.5px solid #f5c4bb;border-radius:8px;padding:9px 16px;font-family:inherit;font-size:13px;font-weight:600;transition:opacity .2s}.btn-danger:hover{opacity:.8}.info-box{color:#7a736e;background:#f0ede6;border-radius:8px;padding:11px 14px;font-size:12px;line-height:1.6}.info-box code{background:#e5e0d8;border-radius:4px;padding:1px 5px;font-size:11px}.toast{color:#fff;z-index:9999;opacity:0;pointer-events:none;background:#3a3530;border-radius:10px;padding:10px 20px;font-size:13px;font-weight:600;transition:opacity .25s;position:fixed;bottom:28px;left:50%;transform:translate(-50%)}.toast.show{opacity:1}.app-topbar{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;background:#ffffffeb;border-bottom:1px solid #e8e4dc;justify-content:space-between;align-items:center;height:48px;padding:0 20px;display:flex;position:fixed;top:0;left:0;right:0}.app-topbar-logo{color:#3a3530;align-items:center;gap:8px;font-size:14px;font-weight:800;display:flex}.app-topbar-logo span{color:#a8a09a;font-size:12px;font-weight:400}.app-topbar-right{align-items:center;gap:10px;display:flex}.topbar-icon-btn{cursor:pointer;background:#f0ede6;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;transition:background .15s;display:flex}.topbar-icon-btn:hover{background:#e5e0d8}.topbar-user{color:#5a5450;align-items:center;gap:7px;font-size:13px;font-weight:600;display:flex}.topbar-user-avatar{color:#fff;background:linear-gradient(135deg,#8b9e8a,#6b8a6a);border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:700;display:flex}.main-content{height:100vh;padding-top:48px;overflow:hidden}.user-list{flex-direction:column;gap:8px;display:flex}.user-row{background:#f5f2ed;border-radius:10px;justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.user-row-info{align-items:center;gap:10px;display:flex}.user-role-badge{border-radius:6px;padding:2px 8px;font-size:11px;font-weight:700}.user-role-badge.admin{color:#4f7a5a;background:#e8f0e7}.user-role-badge.viewer{color:#7a736e;background:#ede8e0}.user-row-actions{gap:6px;display:flex}.btn-sm{cursor:pointer;color:#7a736e;background:#fff;border:1.5px solid #e0ddd6;border-radius:6px;padding:5px 10px;font-family:inherit;font-size:11px;font-weight:600}.btn-sm:hover{opacity:.8}.btn-sm.danger{color:#9a5550;background:#fef2f0;border-color:#f5c4bb}.role-hint{color:#a8a09a;background:#f5f2ed;border-radius:8px;margin-bottom:16px;padding:10px 14px;font-size:12px;line-height:1.6}
